linux环境下,通过mongofiles文件操作MongoDB:
使用--uri参数可以创建一个短连接,在程序中使用比较方便,不需要做开始的初始化或者结束后的断开连接。
官方格式为
mongodb://[username:password@]host1[:port1][,host2[:port2],...[,hostN[:portN]]][/[database][?options]]
参考地址:Connection String URI Format
其中
1. "mongodb://" : uri的标准开头
2. "username:password@" : 连接mongodb所使用的用户名和密码,如果mongodb未开启用户认证,则不填也可以操作成功。如果存在用户名/密码的话,需要用在最后加上分隔符@
3. "host1" : 远程登录的主机ip,如果是连自己主机的话,127.0.0.1即可。
4. ":port1" : 要登录的远程主机端口,不填则默认为27017
5. "hostN:portN" : 如果存在多个需要登录的主机ip,则用逗号隔开即可。
6. "database" : 需要操作的mongodb数据库名称,如果不填的话,默认为admin数据库。
7. "options" : 额外参数,具体参数指定请查看上面的参考地址,或者下面例子(3)的使用方式。
举例:
(1)以用户名为testuser,密码为testpwd,登录127.0.0.1(本机)上的active数据库,并调用list命令,查看其中数据。
./mongofiles --uri mongodb://testuser:[email protected]:27017/active list
(2)若无认证需求,且查看的是admin数据库,则可以简化为
./mongofiles --uri mongodb://127.0.0.1 list
(3)在mongodb3.0版本后其默认采用了SCRAM-SHA-1的认证方式,如果需要调整mongodb主机端的认证方式,可以参考该网址:mongodb3.03开启认证,而如果需要调整客户端这边传输过去的认证方式,可以通过增加options参数实现。
./mongofiles --uri mongodb://testuser:[email protected]:27017/?authMechanism=MONGODB-CR delete_id 111
多个options参数指定之间请用&隔开。
使用过程中的问题:
在实际使用过程中,以例子(1)中的方式调用命令遇到了问题:
在确认过用户名和密码等其他参数都正确的情况下,查看了mongodb中的logs,其中的报错信息为:
UserNotFound: Could not find user XXX@test
其中XXX为使用的用户名,而@之后的就是数据库名,意思为test数据库中找不到XXX用户,即用户不存在或者无操作权限。问题在于参数中的确是指定了对应的数据库active,而数据库端仍然判断为test数据库。
这个问题暂时没找到原因,未确认是特例还是普遍情况。替代方案是使用-d指定对应数据库,即
./mongofiles -d active --uri mongodb://testuser:[email protected]:27017 list
该方式下,命令执行成功。
相关操作命令:
list : 列出数据库数据
put/put_id : 保存文件/且指定id
get/get_id : 根据文件名/id取出文件
delete/delete_id : 根据文件名/id删除文件
具体可参考文档:mongfiles
另外linux下不用配置文件直接启动mongodb:
bin/mongod -dbpath /data/mongo/ -logpath /data/mongo/mongo.log -logappend -fork -port 27017
以后台方式执行。其中dbpath代表数据存储位置,logpath代表日志文件存储位置,具体指定到文件名。