一键安装 MongoDB 数据库脚本

本文涉及的产品
云服务器 ECS,每月免费额度200元 3个月
云数据库 MongoDB,通用型 2核4GB
云服务器ECS,u1 2核4GB 1个月
简介: 【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
目录
相关文章
|
1天前
|
存储 NoSQL 关系型数据库
Percona XtraBackup是否支持MongoDB数据库备份?
【5月更文挑战第13天】Percona XtraBackup是否支持MongoDB数据库备份?
18 1
|
1天前
|
存储 NoSQL MongoDB
MongoDB数据库转换为表格文件的Python实现
MongoDB数据库转换为表格文件的Python实现
15 0
|
1天前
|
算法 数据库 Docker
大模型必备向量数据库-Milvus的安装过程
大模型必备向量数据库-Milvus的安装过程
7 0
|
1天前
|
SQL Oracle 关系型数据库
实验一 安装和使用Oracle数据库
实验一 安装和使用Oracle数据库
11 1
|
1天前
|
数据库 数据库管理 关系型数据库
|
1天前
|
JavaScript 前端开发 NoSQL
【MongoDB 专栏】MongoDB 的 JavaScript 引擎与脚本执行
【5月更文挑战第11天】MongoDB 的 JavaScript 引擎允许在服务器端直接执行脚本,提升效率并实现定制化操作。脚本环境提供独立但与数据库关联的运行空间,引擎负责脚本的解析、编译和执行。执行过程包括脚本提交、解析、编译和执行四个步骤。掌握脚本逻辑设计和 JavaScript 语言特性对于高效利用这一功能至关重要。例如,通过脚本可以计算商品总销售额,增强数据库操作的灵活性。
【MongoDB 专栏】MongoDB 的 JavaScript 引擎与脚本执行
|
1天前
|
负载均衡 关系型数据库 MySQL
关系型数据库的安装和配置数据库节点
【5月更文挑战第5天】关系型数据库的安装和配置数据库节点
125 3
关系型数据库的安装和配置数据库节点
|
1天前
|
存储 NoSQL 关系型数据库
【MongoDB 专栏】MongoDB 与传统关系型数据库的比较
【5月更文挑战第10天】本文对比了MongoDB与传统关系型数据库在数据模型、存储结构、扩展性、性能、事务支持、数据一致性和适用场景等方面的差异。MongoDB以其灵活的文档模型、优秀的扩展性和高性能在处理非结构化数据和高并发场景中脱颖而出,而关系型数据库则在事务处理和强一致性上更具优势。两者各有适用场景,选择应根据实际需求来定。随着技术发展,两者正相互融合,共同构建更丰富的数据库生态。
【MongoDB 专栏】MongoDB 与传统关系型数据库的比较
|
1天前
|
Oracle Unix 关系型数据库
AIX数据库启动和停止脚本
AIX数据库启动和停止脚本
11 1
|
1天前
|
安全 测试技术 数据库
达梦数据库Windows安装教程:从准备到完成
达梦数据库Windows安装教程:从准备到完成
http://www.vxiaotou.com