mongodb分片模式启用认证的注意事项
来源:互联网 发布:mac os10.7镜像下载 编辑:程序博客网 时间:2024/05/19 07:28
启动configsvr
1. 确保mongdb的configsvr是采用service模式启动的,即从/etc/init.d下的脚本启动的,其用户是mongod。
2. 确保mongod的配置文件完全相同。
3. 确保整个集群的所有keyFile文件内容相同。
启动mongos
1. 使用以下命令启动,以确保用户切换为mongod:
runuser -s /bin/bash mongod -c '/usr/bin/mongos --configdb confighost-01:27019,confighost-02:27019,confighost-03:27019 --port 27021 --keyFile /data/mongodb/key.d/mongod.key'
2. 如果发生warning: config servers confighost-01:27019 and confighost-03:27019 differ
可以把configdb目录下的内容删除,然后再次运行configsvr服务。
3. 一切正常后,可以把mongos的启动配置写入脚本/etc/init.d/mongos
4. service mongos start
加入分片
请注意一定在未给admin数据库创建任何用户之前至少加入一个分片,否则可能会导致以后无法加入。
sh.addShard("rs-1/host-11.mycloud.com")
sh.addShard("rs-2/host-21.mycloud.com")
为admin用户创建第一个用户
该用户的角色必须是userAdminAnyDatabase
1.在mongos服务器本机登录
mongo --port xxxxx #xxxxx表示mongos的监听端口
use admin
show dbs #这时可以列出数据库
db.createUser({user: "SysAdmin",pwd: "123",roles: [{role: "userAdminAnyDatabase", db:"admin"}]});
这时退出后再以mongo --port xxxxx登录执行show dbs就显示未授权了。
重新登录
可以选择在本机登录,也可以从其他机器登录。
本机登录:mongo localhost:27021/admin -u SysAdmin -p 123
其他机器登录:mongo mongos-server:xxxxx/admin -u SysAdmin -p 123
为test数据库创建用户
在mongos服务器上以管理员身份登录admin数据库:mongo localhost:27021/admin -u SysAdmin -p 123
为test数据库创建管理员用户:db.createUser({user: "yc-admin",pwd: "123",roles: [ { role: "userAdmin", db: "test" }]});
切换到test数据库:use test
以test管理员身份登录到数据库:db.auth("yc-admin", "123")
创建test的其他用户:
只读用户:db.createUser({user: "yc-read",pwd: "123",roles: [ { role: "read", db: "test" }]});
读写用户:db.createUser({user: "yc-write",pwd: "123",roles: [ { role: "readWrite", db: "test" }]});
添加其它分片
切换到admin数据库
use admin
为admin数据库增加userAdmin用户和root角色的用户(假设用户名是admin-root),见上一步。
clusterAdmin用户:db.createUser({user: "yc-cstadmin",pwd: "123",roles: [ { role: "clusterAdmin", db: "admin" }]});
切换到yc-cstadmin用户:db.auth("yc-cstadmin", "123")
添加rs-3分片:sh.addShard("rs-3/host-31.mycloud.com")
注意:
数据库不同的角色具有不同的权限:
read:只读
readWrite:读写
root:所有
userAdmin:用户管理
clusterAdmin:集群管理和监控
添加分片只能由admin数据库的root进行,其它用户都没有该权限。
0 0
- mongodb分片模式启用认证的注意事项
- mongodb分片模式启用认证的注意事项
- mongodb 启用shareding认证
- mongodb分片环境开启认证
- MongoDB 分片模式部署
- Mongodb 3.2 官方 启用认证
- mongodb 分片的思考
- mongodb的sharding(分片)
- Mongodb的分片部署
- mongodb 分片的思考
- (*)Mongodb的分片配置
- mongodb的分片
- mongoDB 分片的管理
- MongoDB的分片
- MongoDB的分片
- MongoDB的分片测试
- MongoDB分片的搭建
- MongoDB的分片集群
- 李廷馣 飮血更戰 이정암
- 从汇编层面去理解c++中的虚函数
- 从汇编层面去理解对象创建
- OCR损坏RAC集群服务无法启动:CRS-0704、CRS-10132: No msg for has:crs-10132 [10][60]、Could not init OLR
- Linked List Cycle @Leetcode
- mongodb分片模式启用认证的注意事项
- Python 查询Google+相似文档
- [base]Mipmapping Normal Maps
- ubuntu12.04部署ROR
- CentOS Linux服务器安全设置
- Default access privilege in C++
- LeetCode总结 -- 矩阵篇
- Linked List Cycle II@leetcode
- Auto variable in C++