为MongoDB添加身份验证

MongoDB 默认没有开户身份验证,除非不开放外网访问,否则这种模式极不安全,现纪录添加身份验证步骤如下:

 

配置创建用户的时候,需要关闭:

#security:
##副本集之间通信用到的认证文件
# keyFile: /home/soft/mongodb-linux-x86_64-rhel62-3.4.2-shard2/mongo-key
# clusterAuthMode: "keyFile"
##开启身份验证
# authorization: "enabled"

因为你要用use admin,如果你打开授权的话,你又没有密码。故。。。

 

1:在添加验证之前,先运行mongo创建一个管理员用户,否则开户验证后无法登录

use admin
db.createUser(
   {
     user:  "root" ,
     pwd:  "abc123" ,
     roles: [ { role:  "root" , db:  "admin"  } ]
   }
)

有关可用权限列表,参见:https://docs.mongodb.org/manual/reference/built-in-roles/

2:导出keyfile(用于集群之间验证身份),并拷贝到各个机器中

导出认证key文件
openssl rand -base64 741 > mongo-key
chmod  600 mongo-key   #这里必须是600

3:停止mongod线程   ./mongod -f mongod.conf --shutdown

4:在mongod.conf文件中添加如下配置:

添加mongodb用户
 
security:
    ##副本集之间通信用到的认证文件
    keyFile: /home/soft/mongodb-3.2.1/mongo-key
    clusterAuthMode:  "keyFile"
    ##开启身份验证
    authorization:  "enabled"

5:启动mongod

6:启动mongo

7:现在添加其他用途的用户,但首先必须进行身份认证

认证并添加用户
use admin;
db.auth( "root" "abc123" );
创建用户前,首先要切换到要创建用户的数据库,否则会创建到当前库中
 
use datacenter_qc;
db.createUser({ //创建一个可读写datacenter_qc库的用户
     user:  "candao_sys" ,
     pwd:  "candao2016" ,
     roles: [{ role:  "dbOwner" , db:  "datacenter_qc"  }]
});
db.createUser({ //创建一个只读用户
     user:  "candao_user" ,
     pwd:  "candao_2016" ,
     roles: [{ role:  "read" , db:  "datacenter_qc"  }]
});
 
这里需要注意: db,qc环境为:datacenter_qc,正式环境就是:datacenter_release

8:现在在代码中连接数据库时需要指定用户和密码了

修改前:mongodb://192.168.86.73:27017/datacenter_qc?replicaSet=candao_qc
修改后:mongodb://candao_sys:candao2016@192.168.86.73:27017/datacenter_qc?replicaSet=candao_qc&authSource=datacenter_qc
 

转载于:https://www.cnblogs.com/xjf721/p/6479182.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
MongoDB 中,可以使用内置的身份验证功能来实现安全访问和管理数据库身份验证是指确定用户是谁以及他们是否有权访问特定资源的过程。下面是 MongoDB 身份验证的基本流程: 1. 创建管理员用户:首先需要创建至少一个管理员用户,该用户具有创建其他用户和管理数据库的权限。可以使用以下命令在 admin 数据库中创建一个管理员用户: ``` use admin db.createUser( { user: "adminUser", pwd: "adminPassword", roles: [ { role: "userAdminAnyDatabase", db: "admin" } ] } ) ``` 2. 启用身份验证:在 MongoDB 中启用身份验证需要修改配置文件 mongod.conf。需要在配置文件中添加以下配置项: ``` security: authorization: enabled ``` 3. 创建其他用户:创建其他用户并分配相应的权限。可以使用以下命令在指定的数据库中创建一个新用户: ``` use testDB db.createUser( { user: "testUser", pwd: "testPassword", roles: [ { role: "readWrite", db: "testDB" } ] } ) ``` 4. 认证登录:使用 mongo shell 连接到 MongoDB 时,需要提供用户名和密码进行身份验证。可以使用以下命令进行连接: ``` mongo -u testUser -p testPassword --authenticationDatabase testDB ``` 这将会连接到 testDB 数据库,并且使用 testUser 用户名和 testPassword 密码进行身份验证。 相关问题: 1. 如何创建管理员用户? 2. 如何启用 MongoDB 身份验证? 3. 如何创建其他用户并分配相应的权限? 4. 如何使用用户名和密码进行身份验证
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值