停止老版本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不显示操作的库名了。