编辑安装配置文件
vim /etc/yum.repos.d/mongodb-org.repo
配置文件内容
[mogodb-org]
name=MongoDB Repository
baseurl=http://mirrors.aliyun.com/mongodb/yum/redhat/7Server/mongodb-org/4.0/x86_64/
gpgcheck=0
enabled=1
安装 MongoDB
yum -y install mongodb-org
配置MongoDB使其可远程连接
vim /etc/mongod.conf
将
bindIp: 127.0.0.1
改为
bindIp: 0.0.0.0
开机启动脚本
vim /etc/init.d/mongod
内容如下
#! /bin/bash
# chkconfig: 2345 90 91
# description: Start and Stop mongodb
# processname: mongod
EXEC=/usr/bin/mongod
CONF=/etc/mongod.conf
LOCKFILE=/var/lock/subsys/mongod
RETVAL=0
case "$1" in
start)
echo -n $"Starting mongod: "
$EXEC -f $CONF
RETVAL=$?
echo
[ $RETVAL -eq 0 ] && touch $LOCKFILE
;;
stop)
echo -n $"Stopping mongod: "
$EXEC -f $CONF --shutdown
RETVAL=$?
echo
[ $RETVAL -eq 0 ] && rm -f $LOCKFILE
;;
restart)
${0} stop
${0} start
;;
*)
echo "Usage: /etc/init.d/mongod {start|stop|restart}" >&2
exit 1
esac
添加权限
chkconfig --add /etc/init.d/mongod
加入开机启动
systemctl enable mongod
启动
service mongod start
停止
service mongod stop
重启
service mongod restart
卸载
# 停止服务
service mongod stop
# 删除安装的包
yum erase $(rpm -qa | grep mongodb-org)
# 删除数据和日志
rm -rf /var/log/mongodb
rm -rf /var/lib/mongo
进入 mongo 客户端
## 这步开始刚刚安装好mongodb,没有进行什么操作
mongo
use admin
#创建管理员账户(不能创建数据库)
db.createUser({ user: "admin", pwd: "123456", roles: [{ role: "userAdminAnyDatabase", db: "admin" }] })
# 创建超级管理员(可以创建数据库)
db.createUser({user:"root",pwd:"123456",roles:[{role: 'root', db: 'admin'}]})
# 退出
exit
# 登录admin 数据库
mongo admin
use admin
# root管理员登录
db.auth('root','123456');
# 创建test数据库
use test;
# 查看是否有test数据库,结果是没有的
show dbs
# 需要往里面添加数据,test才会生成
db.createCollection("list")
# 查看是否有test数据库,结果是有的
show dbs
#退出
exit
# 重新mongo服务
# 进行mongo 初始化认证,这步是Authentication failed 和connect failed问题解决步骤(这步开始是已经创建好root账号和创建test数据库)
# 登录admin 数据库
mongo admin -u root -p 123456
# 进入 test
use test;
# 创建test数据库的管理员
db.createUser({user: "user1", pwd: "123456", roles:["dbOwner"]})
# 退出
exit
# 可以登录,问题解决
mongo test -u user1 -p 123456
开启防火墙
参考 CentOS防火墙
备份数据库
mongodump -h 172.24.218.101 -u root -p 123456 -d test -o D:\dumpLocal
-h 后接数据库IP,如果端口不是27017的话就冒号+端口,如127.0.0.1:27018
-u 后接用户名
-p 后接密码
-d 后接数据库名
-o 后接备份文件目录,例如Windows下D:\dump\,linux下/data/bak/
还原数据库
mongorestore -h 172.24.218.101 -u root -p 123456 -d test --drop --noIndexRestore D:\dumpLocal\test
-h -u -p -d基本同上
–drop 还原时删除旧的同名库,可以不加
–noIndexRestore 不还原索引,不建议加这个
最后是备份文件位置,不需要-o