设为首页 收藏本站
查看: 1592|回复: 0

[经验分享] Mongodb主从复制开启安全认证

[复制链接]
累计签到:1 天
连续签到:1 天
发表于 2017-9-11 10:26:43 | 显示全部楼层 |阅读模式
2.1.1部署mongodb主从实例:Mongodb-master实例环境:mongodb-master 配置文件先注释掉验证参数:#auth = true
启动mongodb-master 然后设置admin库登陆账户和密码:
[iyunv@localhost logs]# mongo127.0.0.1:27017
MongoDB shell version: 3.0.5
connecting to: 127.0.0.1:27017/test
> use admin;
switched to db admin
> db.createUser(
...   {
...     user:"root",
...     pwd:"Zytest6699",
...    roles: [ { role: "root", db: "admin" } ]
...   }
... )
Successfully added user: {
         "user": "root",
         "roles": [
                   {
                            "role": "root",
                            "db": "admin"
                   }
         ]
}

>db.auth("root","Zytest6699")
1
> show users;
{
         "_id": "admin.root",
         "user": "root",
         "db": "admin",
         "roles": [
                   {
                            "role": "root",
                            "db": "admin"
                   }
         ]
}

到此处开启mongodb-master 配置文件的认证登陆参数:
auth = true
重启mongodb-master服务

登陆mongodb-master在admin库下创建另外一个admin数据库的管理账户:
[iyunv@localhost ~]# mongo 127.0.0.1:27017
MongoDB shell version: 3.0.5
connecting to: 127.0.0.1:27017/test
> use admin;
switched to db admin
>db.auth("root","Zytest6699")
1
> show users;
{
         "_id": "admin.root",
         "user": "root",
         "db": "admin",
         "roles": [
                   {
                            "role": "root",
                            "db": "admin"
                   }
         ]
}

> db.createUser(
...   {
...     user:"ZyDBA",
...     pwd:"Zytest6699",
...    roles: [ { role: "root", db: "admin" } ]
...   }
... )
Successfully added user: {
         "user": "ZyDBA",
         "roles": [
                   {
                            "role": "root",
                            "db": "admin"
                   }
         ]
}
> shou users;
2017-09-10T09:36:18.511+0800 E QUERY    SyntaxError: Unexpected identifier
> show users;
{
         "_id": "admin.root",
         "user": "root",
         "db": "admin",
         "roles": [
                   {
                            "role": "root",
                            "db": "admin"
                   }
         ]
}
{
         "_id": "admin.ZyDBA",
         "user": "ZyDBA",
         "db": "admin",
         "roles": [
                   {
                            "role": "root",
                            "db": "admin"
                   }
         ]
}

Mongod-slave从实例启动mongodb-slave实例:
[iyunv@localhost mongodb-slave]#/etc/init.d/mongod1 start
Starting MongoDB Server...
[iyunv@localhost mongodb-slave]# about tofork child process, waiting until server is ready for connections.
forked process: 1896
child process started successfully, parentexiting

[iyunv@localhost mongodb-slave]# ss-lntup|grep mongo
tcp   LISTEN     0      128                    *:27017                 *:*      users:(("mongod",1709,6))
tcp   LISTEN     0      128                    *:27018                 *:*      users:(("mongod",1896,6))

查看mongodb-slave实例的日志文件:
[iyunv@localhost logs]# tailf/data/mongodb-slave/logs/mongodb.log
2017-09-10T09:55:44.007+0800 I REPL     [replslave] repl: syncing fromhost:127.0.0.1:27017
2017-09-10T09:55:54.008+0800 I REPL     [replslave] repl: syncing fromhost:127.0.0.1:27017
2017-09-10T09:56:04.008+0800 I REPL     [replslave] repl: syncing fromhost:127.0.0.1:27017
2017-09-10T09:56:14.008+0800 I REPL     [replslave] repl: syncing fromhost:127.0.0.1:27017
2017-09-10T09:56:24.008+0800 I REPL     [replslave] repl: syncing fromhost:127.0.0.1:27017
2017-09-10T09:56:34.009+0800 I REPL     [replslave] repl: syncing fromhost:127.0.0.1:27017
2017-09-10T09:56:44.009+0800 I REPL     [replslave] repl: syncing fromhost:127.0.0.1:27017
2017-09-10T09:56:54.009+0800 I REPL     [replslave] repl: syncing fromhost:127.0.0.1:27017
2017-09-10T09:57:04.009+0800 I REPL     [replslave] repl: syncing fromhost:127.0.0.1:27017
提示从库已经开始同步。

2.1.2验证主从复制配置结果安装mongodb 的windows客户端登陆软件来验证操作主从是否配置成功
Robomongo 0.9.0-RC9
主库验证:

2.1.3相关的配置文件以及认证文件单台服务器开启mongodb多实例,以及配置验证主从复制
Mongodb主库配置文件
[iyunv@localhost ~]# cat/usr/local/mongodb/mongod.cnf
logpath=/data/mongodb-master/logs/mongodb.log
logappend = true
#fork and run in background
fork = true
port = 27017
dbpath=/data/mongodb-master/data
#location of pidfile
pidfilepath=/data/mongodb-master/mongod.pid
auth = true
keyFile = /tmp/mongo-keyfile
master = true

mongodb从库配置文件:

[iyunv@localhost ~]# cat/usr/local/mongodb/mongod1.cnf
logpath=/data/mongodb-slave/logs/mongodb.log
logappend = true
#fork and run in background
fork = true
port = 27018
dbpath=/data/mongodb-slave/data
#location of pidfile
pidfilepath=/data/mongodb-svale/mongod.pid
slave = true
source = 127.0.0.1:27017
auth = true
keyFile = /tmp/mongo-keyfile
#only = test001
#only = test002

开启主从复制验证:
随机生成keyFile或者手动写入,key的长度必须是6-1024的base64字符,unix必须相同组权限,windows下不需要
openssl rand -base64 1024>/tmp/mongo-keyfile

启动mongodb-master:

[iyunv@localhost ~]# /etc/init.d/mongodstart
Starting MongoDB Server...
[iyunv@localhost ~]# about to fork childprocess, waiting until server is ready for connections.
forked process: 1287
child process started successfully, parentexiting
[iyunv@localhost data]# ls/data/mongodb-master/data/
journal local.1   local.11  local.13 local.15  local.17  local.3 local.5  local.7  local.9  mongod.lock   _tmp
local.0 local.10  local.12  local.14 local.16  local.2   local.4 local.6  local.8  local.ns storage.bson


mongodb初始化数据库的大data文件特别的大,原因是:
oplog默认的大小是5%点数据库分区挂载点/data的大小,就导致了local数据库过大的问题
[iyunv@localhost data]# du -sh/data/mongodb-master/data/
35G  /data/mongodb-master/data/


运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-404296-1-1.html 上篇帖子: mongodb性能优化 下篇帖子: mongodb日志过大问题处理
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表