Mongodb2.6升级到Mongodb3.0.2笔记

PS:升级到3版本的Mongodb以后,drop集合是可以直接释放磁盘空间的

停止老版本Mongodb

>use admin 
>db.shutdownServer();

下载解压新版本Mongodb

wget https://fastdl.mongodb.org/linux/mongodb-linux-i686-3.0.2.tgz
gzip -d mongodb-linux-i686-3.0.2.tgz
tar xvf mongodb-linux-i686-3.0.2.tar
mv mongodb-linux-i686-3.0.2 mongodb3.0.2

创建两个目录

 

mkdir data
mkdir logs

把老版本的Mongodb配置文件拷贝到新Mongodb目录

cp /data/mongodb2.6.4/mongodb.conf /data/mongodb3.0.2/

 

mongodb.conf内容示例:

bind_ip=127.0.0.1
port=27017
dbpath=/data/mongodb3.0.2/data/
logpath=/data/mongodb3.0.2/logs/mongodb.log
logappend=true
auth=true
fork=true

通过Mongodb3启动Mongodb准备备份

/data/mongodb3.0.2/bin/mongod --dbpath /data/mongodb2.6.4/data/

备份

/data/mongodb3.0.2/bin/mongodump --out /data/mongodb3.0.2/bak/

然后关闭数据库,重新启动,使用WiredTiger引擎

/data/mongodb3.0.2/bin/mongod --storageEngine wiredTiger --dbpath /data/mongodb3.0.2/data/

恢复数据

/data/mongodb3.0.2/bin/mongorestore /data/mongodb3.0.2/bak/

恢复完成以后,再停止Mongodb。

修改mongodb.conf

bind_ip=127.0.0.1
port=27017
dbpath=/data/mongodb3.0.2/data/
logpath=/data/mongodb3.0.2/logs/mongodb.log
logappend=true
auth=true
fork=true
storageEngine=wiredTiger

然后启动Mongodb

/data/mongodb3.0.2/bin/mongod --config /data/mongodb3.0.2/mongodb.conf

------分割线------结果------

about to fork child process, waiting until server is ready for connections.

forked process: 11197

child process started successfully, parent exiting

记得删除先前版本/usr/bin/mongo,把新版本的复制过去

测试了AUTH,一切正常,创建的账户也没丢失。

另外数据相比2版本的,确实占用了很少的空间。以后再也不会随随便便删除集合(释放空间很麻烦),删除数据库了。

[root@localhost mongodb3.0.2]# mongo

MongoDB shell version: 3.0.2

connecting to: test

> use datatest

switched to db datatest

> db.auth('admin','admin')

1

一切正常,删除以前的目录,跟备份数据的目录。

Update:

更新到Mongodb3.0.2版本以后,一切正常,在使用 mongostat的时候,不能像以前一样直接使用

mongostat -u admin -p admin

命令直接查看状态

显示如下:

# mongostat -u admin -p admin

2015-04-16T10:48:13.192+0800    --authenticationDatabase is required when authenticating against a non $external database

现在需要多加个参数“--authenticationDatabase”

命令如下:

# mongostat -u root -p root123 --authenticationDatabase=admin

测试的时候,还只能选择"admin"这个数据库,选择其他的数据库,用其他库的认证账户都不行

错误如下:

2015-04-16T10:49:57.912+0800    Failed: not authorized on admin to execute command { serverStatus: 1, recordStats: 0 }


或者

2015-04-16T10:51:17.267+0800    Failed: error connecting to db server: server returned error on SASL authentication step: Authentication failed.

mongotop命令也一样

另外竟然mongostat不显示操作的库名了。

使用mongodump备份数据,mongorestore恢复数据

#备份所有表
mongodump -h 172.18.92.170 --port 27017   -u 用户名 -p 密码 -o  /usr/local/mongodb/bak/

#恢复所有表
mongorestore  --port 27017 -u 用户名 -p 密码 --authenticationDatabase admin /usr/local/mongodb/bak/

 

转载于:https://my.oschina.net/u/200350/blog/1618731

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值