MongoDB 权限认证

MongoDB 权限认证

  MongoDB已经使用很长一段时间了,基于MongoDB的数据存储也一直没有使用到权限访问(MongoDB默认设置为无权限访问限制),因为考虑到数据安全的原因特地花了一点时间研究了一下,网上搜出来的解决方法大都是3.0以下的版本的,所以不适合3.0+以上的版本。我现在用的版本是MongoDB3.2.7,在windows10系统上进行的验证,估计在win7/win8上应该类似。

  和其它数据库一样,权限的管理都差不多一样。mongodb存储所有的用户信息在admin 数据库的集合system.users中,保存用户名、密码和数据库信息。mongodb默认不启用授权认证,只要能连接到该服务器,就可连接到mongod。若要启用安全认证,需要更改配置文件参数auth

  1、首先,不使用--auth参数启动MongoDB

7481339-9f9c87e87cfc0e1d.gif

systemLog:

    destination: file

    path: C:\data\dblog\mongod.log

    logAppend: truestorage:

    journal:

        enabled: true    dbPath: C:\data\db

net:

    port: 27017#security:

    #authorization: enabled

7481339-a7f71719b5c44955.gif


  mongod -f C:\data\mongodb.conf

7481339-9ef4a8814d96089d.png


  2、启动mongo, 启用admin数据库

7481339-e689063752a6dc02.png

 3、建立一个超级用户admin,命令如下:

  db.createUser( 

  { 

    user: "admin", 

    pwd: "admin123", 

    roles: [ { role: "userAdminAnyDatabase", db: "admin" } ] 

  } )

7481339-6add2d8f8755e209.png

  4、查看用户集合

  db.system.users.find()

7481339-b29a70c4ec15a0a2.png

  5、现在启用auth

  在重启mongod之前,修改配置文件mongo.config,在最下面加入这么一行

  auth = on

   重启mongod

  mongod -f C:\data\mongodb.conf 

7481339-4c41b0d31a324337.png

  然后重启mongo,启用admin数据库,

  显示所有数据库 : show dbs, 发现已经没有权限了

7481339-20a5a65b34ae0994.png

  启用 auth

  db.auth('admin', 'admin123')  返回1表示成功

7481339-8103c421a5c33a6d.png


  再次执行show dbs

7481339-5d0ac8e0aa8d8637.png

  6、 启用ta数据库,查看该数据库集合

7481339-3a0b837a857181c8.png

  很遗憾没有权限,admin虽然是超级管理员,但是对具体的数据库,还是需要有对应的用户,用户是和数据库走的,因此还需要建立ta数据库的用户

  建立针对ta数据库的用户

  db.createUser({user:'test1',pwd:'test1',roles:[{role:'readWrite',db:'ta'}]})

需要注意的是在建立ta数据库用户的时候一定要先启用ta数据库,否则会出现问题

  use ta

7481339-eddc2c5a62441410.png


7481339-1bef761f1c07502a.png

  执行 db.auth('test1','test1')

  然后再对ta数据库进行相应的操作。

7481339-91f5fea8ded46904.png

猜你喜欢

转载自blog.csdn.net/weixin_34212189/article/details/86904856