mongodb分片认证

摘要:
启动configsvr1.确保mongdb的configsvr是采用service模式启动的,即从/etc/init.d下的脚本启动的,其用户是mongod。sh.addShardsh.addShard为admin用户创建第一个用户该用户的角色必须是userAdminAnyDatabase1.在mongos服务器本机登录mongo--portxxxxx#xxxxx表示mongos的监听端口useadminshowdbs#这时可以列出数据库db.createUser;这时退出后再以mongo--portxxxxx登录执行showdbs就显示未授权了。

启动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. servicemongos 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进行,其它用户都没有该权限。

免责声明:文章转载自《mongodb分片认证》仅用于学习参考。如对内容有疑问,请及时联系本站处理。

上篇Oracle10g完全卸载正确步骤8种样式的WEB菜单下篇

宿迁高防,2C2G15M,22元/月;香港BGP,2C5G5M,25元/月 雨云优惠码:MjYwNzM=

相关文章

数据库多租户数据隔离设计

1. 什么是saas系统 “SaaS平台是运营saas软件的平台。SaaS提供商为企业搭建信息化所需要的所有网络基础设施及软件、硬件运作平台,并负责所有前期的实施、后期的维护等一系列服务,企业无需购买软硬件、建设机房、招聘IT人员,即可通过互联网使用信息系统。SaaS 是一种软件布局模型,其应用专为网络交付而设计,便于用户通过互联网托管、部署及接入。” 也...

备份与恢复概述,冷备,热备

对于DBA来说,最基本的工作就是数据库的备份与恢复,在意外情况下(如服务器宕机、磁盘损坏等)要保证数据不丢失,或者是最小程度地丢失。每个DBA应该每时每刻都关心自己所负责的数据库的备份情况。MySQL数据库提供的大多数工具(如mysqldump、ibbackup、replication)都能很好地完成备份的工作,当然也可以通过第三方的一些工具来完成,如xt...

关于MongoDB 配置安全选项(security)后无法正常启动(Unrecognized option: security)

报错为(Unrecognized option: security) 极有可能是你的编码格式不正确(这个错误应该不算是什么问题,但是没有看文档,网上的资料又都是copy,留下笔记希望能够帮到别人) 确保配置文件使用ASCII编码。该mongod的 情况下不支持非ASCII编码,包括UTF-8的配置文件,可以使用notepad编辑器,我将其改为了ANSL编码...

2015.7.30 第十五课 sql(新建数据库、创建表、注释、查询语句、新增、更新、删除、联合查询)

1、认识数据库并新建: 1)打开数据库,连接到服务器。 2)服务里类型不用管。 3)服务器名称:打个点“.”表示服务器在本地计算机,如果是托管在别人的服务器上,就输入服务器IP地址。 4)身份验证:如果是windows身份验证,就需要有管理员权限。一般托管在别人的服务器上,(包括正常情况下),都是用SQL身份验证,需要输入sa和密码(密码就是安装时让输入的...

JAVA连接数据库

运行如下Java程序,学会JAVA连接数据库的方法。。 import java.sql.*; public class Test { public static void main(String[] srg) { String driverName = "com.microsoft.sqlserver.jdbc.SQLServerDriver"; //加载...

数据库实践

前言:此篇博客在参考Regan_White的文章下完成:https://www.cnblogs.com/ReganWhite/p/10944525.html 一、操作数据库(以SQLite3为例)   SQLite3 可使用 sqlite3 模块与 Python 进行集成。它提供了一个与 PEP 249 描述的 DB-API 2.0 规范兼容的 SQL...