mongoDB authentication
转自:http://blog.csdn.net/allen_jinjie/article/details/9235073
1. 最开始的时候,我们启动mongodb,但是不包含--auth参数:
- E:\MongoDB\bin>mongod --dbpath=E:\mongodb\db
- Thu Jul 04 16:31:58.700 [initandlisten] db version v2.4.4
- Thu Jul 04 16:31:58.700 [initandlisten] git version: 4ec1fb96702c9d4c57b1e06dd34eb73a16e407d2
- Thu Jul 04 16:31:58.700 [initandlisten] build info: windows sys.getwindowsversion(major=6, minor=0, build=6002, platform=2, servic
- e_pack='Service Pack 2') BOOST_LIB_VERSION=1_49
- Thu Jul 04 16:31:58.700 [initandlisten] allocator: system
- Thu Jul 04 16:31:58.700 [initandlisten] options: { dbpath: "E:\mongodb\db" }
- Thu Jul 04 16:31:58.731 [initandlisten]
- Thu Jul 04 16:31:58.731 [initandlisten] ** WARNING: mongod started without --replSet yet 1 documents are present in local.system.r
- eplset
- Thu Jul 04 16:31:58.731 [initandlisten] ** Restart with --replSet unless you are doing maintenance and no other clients a
- re connected.
- Thu Jul 04 16:31:58.731 [initandlisten] ** The TTL collection monitor will not start because of this.
- Thu Jul 04 16:31:58.731 [initandlisten] ** For more info see http://dochub.mongodb.org/core/ttlcollections
- Thu Jul 04 16:31:58.731 [initandlisten]
- Thu Jul 04 16:31:58.981 [initandlisten] waiting for connections on port 27017
- Thu Jul 04 16:31:58.981 [websvr] admin web console waiting for connections on port 28017
另开一Dos窗口,直接连接到test数据库上:
- E:\MongoDB\bin>mongo
- MongoDB shell version: 2.4.4
- connecting to: test
2. 连接到admin数据库,在admin数据库上创建一个用户,这个用户保存在admin.system.users中,它的权限比在其它数据库中设置的用户权限更大。(当admin.system.users中一个用户都没有时,即使mongod启动时添加了--auth参数,如果没有在admin数据库中添加用户,此时不进行任何认证还是可以做任何操作,直到在admin.system.users中添加了一个用户。)
- > use admin
- switched to db admin
- > db.system.users.find()
- > db.addUser("allenlei","123456")
- {
- "user" : "allenlei",
- "readOnly" : false,
- "pwd" : "a9eadc99bab4734b32f5bc4148d866c6",
- "_id" : ObjectId("51d534878704a2ac963ed790")
- }
- > db.system.users.find()
- { "_id" : ObjectId("51d534878704a2ac963ed790"), "user" : "allenlei", "readOnly" : false, "pwd" : "a9eadc99bab4734b32f5bc4148d866c6
- " }
- >
3. 现在admin数据库中已经有用户信息了,我们关掉mongodb, 重新启动,这次带有--auth 参数。
- E:\MongoDB\bin>mongod --dbpath=E:\mongodb\db --auth
- Thu Jul 04 16:44:57.393 [initandlisten] db version v2.4.4
- Thu Jul 04 16:44:57.393 [initandlisten] git version: 4ec1fb96702c9d4c57b1e06dd34eb73a16e407d2
- Thu Jul 04 16:44:57.409 [initandlisten] build info: windows sys.getwindowsversion(major=6, minor=0, build=6002, platform=2, servic
- e_pack='Service Pack 2') BOOST_LIB_VERSION=1_49
- Thu Jul 04 16:44:57.409 [initandlisten] allocator: system
- Thu Jul 04 16:44:57.409 [initandlisten] options: { auth: true, dbpath: "E:\mongodb\db" }
- Thu Jul 04 16:44:57.440 [initandlisten]
- Thu Jul 04 16:44:57.440 [initandlisten] ** WARNING: mongod started without --replSet yet 1 documents are present in local.system.r
- eplset
- Thu Jul 04 16:44:57.440 [initandlisten] ** Restart with --replSet unless you are doing maintenance and no other clients a
- re connected.
- Thu Jul 04 16:44:57.440 [initandlisten] ** The TTL collection monitor will not start because of this.
- Thu Jul 04 16:44:57.440 [initandlisten] ** For more info see http://dochub.mongodb.org/core/ttlcollections
- Thu Jul 04 16:44:57.440 [initandlisten]
- Thu Jul 04 16:44:57.549 [websvr] admin web console waiting for connections on port 28017
- Thu Jul 04 16:44:57.549 [initandlisten] waiting for connections on port 27017
4. 由于指定了-auth参数,那么连接到数据库上就需要提供登录账户,尽管不提供也可以登录到test这个默认数据库,但是没办法操作:
- E:\MongoDB\bin>mongo
- MongoDB shell version: 2.4.4
- connecting to: test
- > show collections
- Thu Jul 04 16:53:51.752 JavaScript execution failed: error: {
- "$err" : "not authorized for query on test.system.namespaces",
- "code" : 16550
- } at src/mongo/shell/query.js:L128
- >
5. 现在我们指定连接到admin数据库,如果账户不对:
- E:\MongoDB\bin>mongo --authenticationDatabase admin -u allenlei -p
- MongoDB shell version: 2.4.4
- Enter password:
- connecting to: test
- Thu Jul 04 16:56:55.569 JavaScript execution failed: Error: 18 { code: 18, ok: 0.0, errmsg: "auth fails" } at src/mongo/shell/db.j
- s:L228
- exception: login failed
6. 奇怪的是,就算是账户正确,我的机器上也是显示连接到test数据库而不是admin。我需要转到admin数据库上,(root是建立在test数据库上的账户)
- E:\MongoDB\bin>mongo --authenticationDatabase admin -u allenlei -p
- MongoDB shell version: 2.4.4
- Enter password:
- connecting to: test
- > db.system.users.find()
- { "_id" : ObjectId("51d3e1c94ef3aba14566b889"), "user" : "root", "readOnly" : false, "pwd" : "b3098ef4591719e9f75972a75883726b" }
- > use admin
- switched to db admin
- > db.system.users.find()
- { "_id" : ObjectId("51d5378a6a7de1fde965535c"), "user" : "allenlei", "readOnly" : false, "pwd" : "a9eadc99bab4734b32f5bc4148d866c6
- " }
- >
- > show collections
- system.indexes
- system.users
- > use tutorial
- switched to db tutorial
- > show collections
- newCollection_noCapped
- numbers
- person
- personalinfo
- photo.chunks
- photo.files
- student
- student_res
- system.indexes
- system.users
- users
- >
可以看出,通过admin数据库登入,可以以登录账户进入其他数据库进行操作。
7. 现在用root账号登入test数据库:
- E:\MongoDB\bin>mongo -authenticationDatabase test -u root -p
- MongoDB shell version: 2.4.4
- Enter password:
- connecting to: test
- > show collections
- person
- system.indexes
- system.users
- > db.system.users.find()
- { "_id" : ObjectId("51d53a706ce04d74431706b4"), "user" : "root", "readOnly" : false, "pwd" : "34e5772aa66b703a319641d42a47d696" }
- > use tutorial
- switched to db tutorial
- > show collections
- Thu Jul 04 17:04:51.186 JavaScript execution failed: error: {
- "$err" : "not authorized for query on tutorial.system.namespaces",
- "code" : 16550
- } at src/mongo/shell/query.js:L128
- >
root账户属于test而不是admin数据库,权限只能在本数据库使用,而不像allenlei可以到tutorial数据库操作。
mongoDB authentication的更多相关文章
- 用navicat进行身份验证连接出现cannot connect to Mongodb authentication failed
用navicat进行身份验证连接出现cannot connect to Mongodb authentication failed. 解决办法: 1.打开mongoDB连接 win+r --cmd-- ...
- MongoDB authentication failed
0.随笔摘要: MongoDB 安装配置 MongoDB 权限控制 MongoDB 注意事项 authentication failed 1.MongoDB 下载安装配置 MongoDB官网 ...
- [转]mongodb authentication 设置权限之后,新建个管理账户和一般数据库用户,在win 7 64bit 环境下测试使用实例
如果之前安装mongodb时没有使用 --auth,那么必须要卸载MongoDB服务,进行重新安装,设置账号权限才生效! 主要是解决在测试使用mongo db 时候,总是出现的MongoAuthent ...
- windows7下MongoDB(V3.4)的使用及仓储设计
简单的介绍一下,我使用MongoDB的场景. 我们现在的物联网环境下,有部分数据,采样频率为2000条记录/分钟,这样下来一天24*60*2000=2880000约等于300万条数据,以后必然还会增加 ...
- 单点登录(十三)-----实战-----cas4.2.X登录启用mongodb验证方式完整流程
我们在之前的文章中中已经讲到了正确部署运行cas server 和 在cas client中配置. 在此基础上 我们去掉了https的验证,启用了http访问的模式. 单点登录(七)-----实战-- ...
- MongoDB 用户名密码登录
Mongodb enable authentication MongoDB 默认直接连接,无须身份验证,如果当前机器可以公网访问,且不注意Mongodb 端口(默认 27017)的开放状态,那么Mon ...
- RESTheart安装与设置
作者:Maurizio Turatti, 最后在Feb 25, 2016时被 Andrea Di Cesare更新 安装与设置 1. 快速开始 Docker Vagrant Bare metal 2. ...
- mongodb 使用mongodump备份 指定用户名密码 出现错误 Failed: error connecting to db server: server returned error on SASL authentication step: Authentication failed
mongodb 使用mongodump备份 指定用户名密码 出现错误 [root@MongoDB ~]# mongodump --host -u admin -p -d db1 -o /root/ F ...
- mongodb的认证(authentication)与授权(authorization)
一小白瞎整mongodb,认证部分被折磨的惨不忍睹,看厮可怜,特查了一下文档,浅显地总结一下mongodb认证(authentication)与授权(authorization)的联系. 创建的所有用 ...
随机推荐
- hdu 1250 简单大整数加法
#include<stdio.h> #include<string.h> #define N 3100 int a[N],b[N],c[N],d[N],e[N]; int ma ...
- 初步了解Shuttle ESB
ESB:EnterpriseService Bus,即企业服务总线.它是传统中间件技术与XML.Web服务等技术结合的产物.从面向服务体系架构发展而来. ESB採用了"总线"这种模 ...
- 【c语言】 模拟实现库函数的atoi函数
// 模拟实现库函数的atoi函数 #include <stdio.h> #include <string.h> #include <assert.h> #incl ...
- 创建quickstart报错
在cmd中创建helloword成功(一开始是mvn package失败,后面又执行了一遍又成功了,应该是网络问题) 然后在eclipse 中创建quickstart,结果pom报错找不到如下包 ma ...
- 关于jetty服务器默认首页和端口设置
一.jetty服务器部署.启动成功后,在浏览器输入http://localhost:8080/ 可以直接访问到jetty欢迎首页. 这是因为在Jetty包中默认带了一个test.war的应用,在${J ...
- 车牌识别(end-to-end-for-chinese-plate-recognition)项目搭建基于Mxnet(Python 3.5)
最近看到geihub上有个车牌识别的项目,感觉很有意思,从上面fork了一下弄到本地自己跑了下.在安装过程中遇到了一些问题,记录如下. 项目github连接:https://github.com/sz ...
- Android5.1 在init.rc 中添加自己的服务【转】
本文转载自:http://blog.csdn.net/VOlsenBerg/article/details/71085610 我有一个需求就是在Android系统开机的时候把一个配置文件放到Andro ...
- Head First 设计模式 —— 装饰器模式
1. 装饰器模式与继承 与装饰器模式相比,继承更容易造成类爆炸: 装饰器模式:利用组合取代继承:
- EOJ 2844 排序去重
有 n 个 1 到 1000 之间的整数 (1≤n≤100),对于其中重复的数字,只保留一个,把其余相同的数去掉.然后再按照指定的排序方式把这些数排序. Input 第 1 行为字母 A 或 D,A ...
- mysql5.7下面windows平台大小写敏感
转自:https://blog.csdn.net/lrl219/article/details/52889582 根据网上的信息在my.ini下面的mysqld的配置下面添加lower_case_ta ...