一键安装 MongoDB 数据库脚本

本文涉及的产品
云服务器 ECS,u1 4核16GB 1个月
云服务器 ECS,u1 4核8GB 1个月
云服务器 ECS,每月免费额度200元 3个月
简介: 【4月更文挑战第29天】

》》》》》魏红斌带你学shell脚本《《《《《


更多shell脚本学习点击个人主页


作为一个资深程序猿,我将带领您从零开始,一步步踏上运维之旅,无论您是否拥有现成的服务器,都将学会如何轻松购买、部署,并通过编写及应用精心设计的Shell脚本,解决实际工作中遇到的问题。这些脚本不仅源自真实的业务场景,经历了反复实践与严格测试,确保了其简洁高效、易于理解且便于使用。更重要的是,我们将全程免费分享,并深度解析背后原理,助您深入理解并灵活运用,每一款脚本均经过真实业务场景的反复打磨与严格测试,秉持着简洁高效、易于理解和使用的理念设计,无偿提供并且提供相关解析过程,让读者能更深入了解相关内容

无服务器的朋友们

让我们先从选购并部署服务器开始。只需简单三步,即可拥有您的专属云服务器:

  1. 访问ECS官网:点击链接直达阿里云ECS网站:ECS选择网址。这是您获取高质量云服务器的第一站。
  2. 选择并购买:在琳琅满目的服务器配置中,挑选符合您需求的那一款,一键下单,完成支付。整个过程犹如在线购物般便捷。
  3. 进入ECS控制台:支付成功后,您将被引导至ECS管理控制台。在这里,您可以全面掌控您的服务器资源,后续的所有运维操作都将在此展开。

已有服务器的朋友们

如果您已拥有ECS实例,那么请直接登录ECS管理控制台在左侧导航栏中,依次选择“实例与镜像” > “实例”,确保您已定位到目标资源所在的资源组和地域。接下来,在实例列表中找到待连接的实例,点击操作列下的“远程连接”,选择“通过Workbench远程连接”并点击“立即登录”。

登录实例

无论是新购还是已有服务器,接下来都需要进行实例登录。这里支持多种认证方式,以最常见的“密码认证”为例:

  • 输入用户名(通常为rootecs-user)。
  • 接着,输入登录密码。如果您忘记了密码,无需担忧,您可以在ECS实例详情页面查询,或者通过“更改密码”功能进行修改。

编写与运行Shell脚本

成功登录后,您将看到一个熟悉的命令行界面——这就是您的运维主战场。现在,键入vim test.sh,我们便进入了文本编辑模式,准备创建第一个Shell脚本。

按下键盘上的i键,进入插入模式,此刻您可以自由地复制粘贴今天要学习的脚本代码,粘贴后按ecs后,按:wq保存脚本,可以用./ test.sh或者sh test.sh进行脚本执行。

今天我们要学习的脚本是(脚本内容直接复制粘贴即可):

#!/bin/bash

#

#********************************************************************

#Author: wangxiaochun

#QQ: 29308620

#Date: 2021-02-19

#FileName: install_mongodb.sh

#Description: The test script

#Copyright (C): 2021 All rights reserved

#********************************************************************

file=mongodb-linux-x86_64-ubuntu1804-4.4.4.tgz

url=https://fastdl.mongodb.org/linux/$file

db_dir=/data/db

install_dir=/usr/local

port=27017

color () {

RES_COL=60

MOVE_TO_COL="echo -en \\033[${RES_COL}G"

SETCOLOR_SUCCESS="echo -en \\033[1;32m"

SETCOLOR_FAILURE="echo -en \\033[1;31m"

SETCOLOR_WARNING="echo -en \\033[1;33m"

SETCOLOR_NORMAL="echo -en \E[0m"

echo -n "$2" && $MOVE_TO_COL

echo -n "["

if [ $1 = "success" -o $1 = "0" ] ;then

${SETCOLOR_SUCCESS}

echo -n $" OK "

elif [ $1 = "failure" -o $1 = "1" ] ;then

${SETCOLOR_FAILURE}

echo -n $"FAILED"

else

${SETCOLOR_WARNING}

echo -n $"WARNING"

fi

${SETCOLOR_NORMAL}

echo -n "]"

echo

}

os_type (){

awk -F'[ "]' '/^NAME/{print $2}' /etc/os-release

}

check () {

[ -e $db_dir -o -e $install_dir/mongodb ] && { color 1 "MongoDB 数据库已安

装";exit; }

if [ `os_type` = "CentOS" ];then

rpm -q curl &> /dev/null || yum install -y -q curl

elif [ `os_type` = "Ubuntu" ];then

dpkg -l curl &> /dev/null || apt -y install curl

else

color 1 不支持当前操作系统

exit

fi

}

file_prepare () {

if [ ! -e $file ];then

curl -O $url || { color 1 "MongoDB 数据库文件下载失败"; exit; }

fi

}

install_mongodb () {

tar xf $file -C $install_dir

mkdir -p $db_dir

ln -s $install_dir/mongodb-linux-x86_64-* $install_dir/mongodb

echo PATH=$install_dir/mongodb/bin/:'$PATH' > /etc/profile.d/mongodb.sh

. /etc/profile.d/mongodb.sh

mongod --dbpath $db_dir --bind_ip_all --port $port --logpath

$db_dir/mongod.log --fork

[ $? -eq 0 ] && color 0 "MongoDB 数据库安装成功!" || color 1 "MongoDB 数据库安装

失败!"

}

check

file_prepare

install_mongodb

以下是脚本的主要功能和步骤解析:

  1. 定义变量:
  • $file: MongoDB的安装包名称,指定版本为4.4.4,适用于Ubuntu 18.04。
  • $url: MongoDB安装包的下载URL。
  • $db_dir: 数据库存放目录。
  • $install_dir: MongoDB的安装目录。
  • $port: MongoDB运行的端口号。
  1. 定义色彩输出函数 (color): 用于在终端以不同颜色显示成功、失败或警告信息。
  2. 检测操作系统类型函数 (os_type): 利用/etc/os-release文件判断当前系统是CentOS还是Ubuntu。
  3. 检查环境及依赖函数(check):
  • 检查数据库是否已安装,如果已存在数据库目录或安装目录,则输出失败信息并退出。
  • 根据操作系统类型安装curl(用于后续下载MongoDB安装包)。
  1. 准备文件函数(file_prepare):
  • 如果MongoDB安装包不存在,使用curl从指定URL下载。
  1. 安装MongoDB函数(install_mongodb):
  • 解压下载的安装包到指定安装目录。
  • 创建数据存储目录,并创建软链接简化路径。
  • 更新环境变量,使MongoDB的命令可以在任何路径下执行。
  • 配置MongoDB以允许所有IP连接,指定端口和日志路径,并以后台进程方式启动。
  • 检查MongoDB是否成功启动,并通过color函数输出结果。
  1. 脚本执行流程:
  • 先执行check检查环境,
  • 然后调用file_prepare确保安装包就绪,
  • 最后执行install_mongodb完成MongoDB的安装与配置。

注意:此脚本未包含防火墙规则调整、SELinux设置(如果适用)以及服务管理脚本的创建,这些可能根据具体系统环境需要额外手动配置。此外,直接以root权限运行此脚本可能存在安全隐患,请确保理解脚本操作并采取适当安全措施。

如果想上手操作练代码的同学们可以通过阿里云ecs服务器免费试用参与!

入口:新老同学免费试用

相关实践学习
MongoDB数据库入门
MongoDB数据库入门实验。
快速掌握 MongoDB 数据库
本课程主要讲解MongoDB数据库的基本知识,包括MongoDB数据库的安装、配置、服务的启动、数据的CRUD操作函数使用、MongoDB索引的使用(唯一索引、地理索引、过期索引、全文索引等)、MapReduce操作实现、用户管理、Java对MongoDB的操作支持(基于2.x驱动与3.x驱动的完全讲解)。 通过学习此课程,读者将具备MongoDB数据库的开发能力,并且能够使用MongoDB进行项目开发。   相关的阿里云产品:云数据库 MongoDB版 云数据库MongoDB版支持ReplicaSet和Sharding两种部署架构,具备安全审计,时间点备份等多项企业能力。在互联网、物联网、游戏、金融等领域被广泛采用。 云数据库MongoDB版(ApsaraDB for MongoDB)完全兼容MongoDB协议,基于飞天分布式系统和高可靠存储引擎,提供多节点高可用架构、弹性扩容、容灾、备份回滚、性能优化等解决方案。 产品详情: https://www.aliyun.com/product/mongodb
目录
相关文章
|
19天前
|
NoSQL MongoDB Python
【Python】已完美解决(MongoDB安装报错)Service ‘MongoDB Server (MongoDB)’ (MongoDB) failed tostart
【Python】已完美解决(MongoDB安装报错)Service ‘MongoDB Server (MongoDB)’ (MongoDB) failed tostart
25 1
|
2天前
|
Oracle 安全 关系型数据库
|
2天前
|
存储 Oracle 关系型数据库
|
3天前
|
存储 Oracle 关系型数据库
关系型数据库Oracle运行RMAN脚本
【7月更文挑战第23天】
12 4
|
3天前
|
监控 Oracle 算法
|
3天前
|
Oracle 关系型数据库 数据库
关系型数据库Oracle编写RMAN脚本
【7月更文挑战第23天】
12 2
|
4天前
|
Oracle 关系型数据库 数据库
关系型数据库Oracle执行RMAN脚本
【7月更文挑战第22天】
14 2
|
4天前
|
Oracle 关系型数据库 数据库连接
|
6天前
|
关系型数据库 MySQL 测试技术
数据库升级是一个涉及数据备份、新版本安装、数据迁移和测试等关键环节的复杂过程
【7月更文挑战第21天】数据库升级是一个涉及数据备份、新版本安装、数据迁移和测试等关键环节的复杂过程
15 1
|
11天前
|
SQL Oracle 关系型数据库
MySQL、SQL Server和Oracle数据库安装部署教程
数据库的安装部署教程因不同的数据库管理系统(DBMS)而异,以下将以MySQL、SQL Server和Oracle为例,分别概述其安装部署的基本步骤。请注意,由于软件版本和操作系统的不同,具体步骤可能会有所变化。
46 3