最近自己开发了一个小程序服务端用到了mongodb存储数据, 去阿里云看了一下mongodb价格最低配一年也要七千多,果然不是我这种穷人能用的起的, 所以果断在自己的ECS服务器上搭建了一个,反正不是什么太专业的项目安全性稳定性之类的也就无所谓了,在这里把搭建步骤和遇到的坑记录一下,方便自己以后查看,也可以为有同样需求的朋友提供一些参考.
1. 下载安装
MongoDB 提供了 linux 各发行版本 64 位的安装包,你可以在官网下载安装包。
下载地址:https://www.mongodb.com/download-center#community
如下图所示选择相应的版本,系统点击Download下载
下载成功后,将下载的文件传到服务器的自己想要安装的相应的文件夹, 我的是在/usr/local/下面
# 解压 将mongodb-linux-x86_64-rhel70-4.0.5.tgz 换成你自己下载的安装包名
tar -zxvf mongodb-linux-x86_64-rhel70-4.0.5.tgz
# 将解压包拷贝到指定目录 移动或改名,感觉不需要的也可以不改
mv mongodb-linux-x86_64-rhel70-4.0.5 /usr/local/mongodbserver
MongoDB 的可执行文件位于 bin 目录下,所以可以将其添加到 PATH 路径中:
# 为你 MongoDB 的安装路径。如本文的 /usr/local/mongodbserver
export PATH=/bin:$PATH
2.创建数据库目录,日志目录
MongoDB的数据存储在data目录的db目录下,但是这个目录在安装过程不会自动创建,所以你需要手动创建data目录,并在data目录中创建db目录。
本文将data目录创建于根目录下(/)。
注意:/data/db 是 MongoDB 默认的启动的数据库路径(--dbpath)。
#创建数据目录
mkdir -p /data/db
#顺便创建日志目录
mkdir -p /data/logs
3.创建配置文件
mongodb的启动文件是安装目录下的bin目录下面的mongod文件,你可以通过执行该文件来启动mongodb服务(不推荐)
./mongod
更好的方式是通过配置启动
#为了方便我们直接把配置文件创建在bin目录下面
cd /usr/local/mongodbserver/bin
vim mongodb.conf
将下面代码拷贝到mongodb.conf中
dbpath = /data/db #数据文件存放目录
logpath = /data/logs/mongodb.log #日志文件存放目录
port = 27017 #端口
fork = true #以守护程序的方式启用,即在后台运行
auth=true #验证用户名密码
logappend=true
bind_ip=0.0.0.0 #这里默认是127.0.0.1, 设置成0.0.0.0是表示所有IP地址都可以访问(后面会具体介绍)
保存退出.
4.启动MongoDB
cd /usr/local/mongodbserver/bin
./mongod -f ./mongodb.conf
启动成功会看到类似这种提示
5.添加管理用户
(mongoDB 没有无敌用户root,只有能管理用户的用户 userAdminAnyDatabase)
利用mongo命令连接mongoDB服务器端:
cd /usr/local/mongodbserver/bin
./mongo
#选择admin数据库
use admin
#创建用户(用户名密码自行修改)
db.createUser( {user: "admin",pwd: "123456",roles: [ { role: "userAdminAnyDatabase", db: "admin" } ]});
创建成功后会看到类似这种提示
添加完管理用户后,关闭MongoDB,并使用权限方式再次开启MongoDB,这里注意不要使用kill直接去杀掉mongodb进程,(如果这样做了,请去data/db目录下删除mongo.lock文件),可以使用db.shutdownServer()关闭.
进入mongo shell,使用admin数据库并进行验证,如果不验证,是做不了任何操作的。
> use admin
> db.auth("admin","123456") #认证,返回1表示成功
6.外网连接mongodb
到此基本功能就已经差不多了,但我们远程连接时很可能会发现连接不上mongodb,这里一般是有两个原因造成的.
- mongodb.conf中的bind_ip配置的是127.0.0.1或者没有配置,对安全性要求不高的话可以直接配置成0.0.0.0,表示所有IP都可以连接到mongodb服务.
- 如果配置成成了0.0.0.0还是连接不上的话,八成就是防火墙配置的问题了.
打开防火墙配置文件
vim /etc/sysconfig/iptables
#增加如下命令
-A INPUT -p tcp --dport 27017 -j ACCEPT
保存退出,然后重启防火墙服务
service iptables restart
再次尝试连接应该就可以了,如果还是不行,请自行检查上面两个原因.
下面几项仅为了操作方便也可以不设置:
7.将mongod路径添加到系统路径中,方便随处执行mongod命令
- 在/etc/profile文件中,添加 export PATH=$PATH:/usr/local/mongodbserver/bin
- 执行source /etc/profile,使系统环境变量立即生效
8. 将mongo路径软链到/usr/bin路径下,方便随处执行mongo命令
- 执行命令: ln -s /usr/local/mongodbserver/bin/mongo /usr/bin/mongo
- 测试是否方便随处执行mongo命令, 回到任意路径下,执行mongo命令,连接mongod服务
- 关闭mongod服务,执行db.shutdownServer(), 这里可能遇到权限不足问题解决方法如下
#添加权限
db.updateUser(
"admin",
{
roles : [
{"role" : "userAdminAnyDatabase","db" : "admin"},
{"role" : "dbOwner","db" : "admin"},
{"role" : "clusterAdmin", "db": "admin"}
]
}
)
然后再执行db.shutdownServer()关闭mongodb服务,或执行下面语句关闭服务
killall mongod
- 启动mongod服务
mongod --config /usr/local/mongodbserver/bin/mongodb.conf
9.MongoDB设置为系统服务并且设置开机启动
- 通过上面简单的操作,我们已经将MongoDB配置文件配置完成,那么接下里我们将为MongoDB设置系统服务。
- 首先添加MongoDB系统服务,命令如下:vim /etc/rc.d/init.d/mongod
- 打开编辑器后,我们将下面的配置粘贴进去,然后保存
start() {
/usr/local/mongodbserver/bin/mongod --config /usr/local/mongodbserver/bin/mongodb.conf
}
stop() {
/usr/local/mongodbserver/bin/mongod --config /usr/local/mongodbserver/bin/mongodb.conf --shutdown
}
case "$1" in
start)
start
;;
stop)
stop
;;
restart)
stop
start
;;
*)
echo
$"Usage: $0 {start|stop|restart}"
exit 1
esac
- 保存完成之后,添加脚本执行权限,命令如下:chmod +x /etc/rc.d/init.d/mongod
-
启动MongoDB,service mongod start 如下图所示,则说明启动成功:
- 可以使用命令service mongod stop关闭MongoDB服务。
- 验证mongoDB是否启动,输入命令lsof -i :27017,监测端口已经在使用中,所以说启动已经完成。
参考文献
https://www.jianshu.com/p/586da7c8fd42
http://www.runoob.com/mongodb/mongodb-linux-install.html
https://www.baidu.com/link?url=5LXYbCn137NLi7tl4WAGcTSLLbUSHvyzP9O9CzcAVf9TDe-bJ_Rbaa6wbuWDbIHEUjdKDatGvKQndQWvrQit_q&wd=&eqid=bdc8d6220000dfeb000000045c4324c7