CentOS7 使用阿里镜像安装 MongoDB

编辑安装配置文件

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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值