MongoDB4.2.6集群添加用户认证

2020-04-21  本文已影响0人  李小二的倔强

没来由此去经年,总把新人换旧颜。
江山父老能容我,不使人间造孽钱。

今天主要介绍的是给集群加上用户的验证
集群配置:

主节点——172.31.129.12
从节点——172.31.129.13
仲裁节点——172.31.129.17

这里对配置文件进行一下说明:

MongoDB服务支持命令行配置参数和配置文件两种启动方式, 为便于管理, 推荐使用配置文件进行服务参数的配置. 自Mongo2.6版起, 官方推荐使用YAML格式的配置参数: MongoDB官方YAML配置文件参数说明; 旧版配置文件格式依然可用但不建议使用: .MongoDB官方旧版配置文件参数说明
我这里用的是旧版的格式,有兴趣也可以尝试yaml格式,
下面是本集群使用的配置文件mongod.conf

port=27017 #端口 
dbpath= /usr/local/pid/mongodb-linux-x86_64-rhel70-4.2.6.tgz/db #数据库存文件存放目录 
logpath= /usr/local/pid/mongodb-linux-x86_64-rhel70-4.2.6.tgz/mongodb.log #日志文件存放路径 
logappend=true #使用追加的方式写日志 
fork=true #不以守护程序的方式启用,即不在后台运行 
replSet=sdb #Replica Set的名字 集群名称 
maxConns=100 #最大同时连接数 
> #auth=true #启用验证
> #keyFile=/usr/local/pid/mongodb-linux-x86_64-rhel70-4.2.6.tgz/access.key
journal=true #每次写入会记录一条操作日志(通过journal可以重新构造出写入的数据)。 
#即使宕机,启动时wiredtiger会先将数据恢复到最近一次的checkpoint点,然后重放后续的journal日志来恢复。 
storageEngine=wiredTiger #存储引擎有mmapv1、wiretiger、mongorocks 
bind_ip = 0.0.0.0 #这样就可外部访问了,例如从win10中去连虚拟机中的MongoDB

和以前的配置一样,只是加了auth和keyFile的属性,暂时先注释掉

确定你集群正常启动的状态,现在开始添加集群用户

集群配置完成后, 仍然在主节点的mongo控制台中添加三个用户:数据库管理员, 集群管理员和访问特定数据库的用户.
在一个节点执行就可以

#在bin目录下
#进入mongo控制台
./mongo 172.31.129.12  

#使用内置的admin库   
> use admin                
> db.createUser({user:"admin",pwd:"admin",roles:[{role:"readWriteAnyDatabase",db:"admin"},{role:"dbAdminAnyDatabase",db:"admin"},{role:"userAdminAnyDatabase",db:"admin"}]})

 #创建集群管理员
> db.createUser({user:"cluster",pwd:"cluster",roles:[{role:"clusterAdmin",db:"admin"},{role:"clusterManager",db:"admin"},{role:"clusterMonitor",db:"admin"}]})

 #切换到pid数据库,不用事先创建
> use pid                
> db.createUser({user:"pid21",pwd:"pid21@cnic",roles:[{role:"readWrite",db:"pid"},{role:"dbAdmin",db:"pid"},{role:"userAdmin",db:"pid"}]})

 #查看创建的用户
> use admin
> db.system.users.find()    

开启用户认证

用户添加完成后需要关闭所有节点(先关闭仲裁和从节点, 再关闭主节点, 避免主节点切换)

生成keyFile(keyFile的用途是作为所有mongod后台进程允许加入集群的凭证, 所有集群中的节点共用一个keyFile, 避免其他mongod加入集群)
在一个节点执行
#生成keyFile, keyFile的长度必须在6-1024个字符之间
openssl rand -base64 756 >  /usr/local/pid/access.key
#keyFile文件权限为只读     
chmod 400 /usr/local/pid/access.key
#用scp将keyFile复制到其他服务器    
scp /usr/local/pid/access.key root@172.31.129.13:/usr/local/pid
scp /usr/local/pid/access.key root@172.31.129.17:/usr/local/pid  

取消三个节点上的auth和keyFile的注释(用户进行认证是要把noauth属性删除):
依次启动主节点, 从节点和仲裁节点
在配置文件中修改:

spring:
  data:
    mongodb:
      uri: mongodb://admin:admin@172.31.129.12:27017,172.31.129.13:27017/pid?replicaSet=sdb&slaveOk=true&readPreference=secondaryPreferred
上一篇 下一篇

猜你喜欢

热点阅读