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

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

[复制链接]

尚未签到

发表于 2018-10-25 07:55:23 | 显示全部楼层 |阅读模式
2.1.1部署mongodb主从实例:
Mongodb-master实例
  环境:mongodb-master 配置文件先注释掉验证参数:#auth = true
  启动mongodb-master 然后设置admin库登陆账户和密码:
  [root@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数据库的管理账户:
  [root@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>  > 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实例:
  [root@localhost mongodb-slave]#/etc/init.d/mongod1 start
  Starting MongoDB Server...
  [root@localhost mongodb-slave]# about tofork child process, waiting until server is ready for connections.
  forked process: 1896
  child process started successfully, parentexiting
  [root@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实例的日志文件:
  [root@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主库配置文件
  [root@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从库配置文件:
  [root@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:
  [root@localhost ~]# /etc/init.d/mongodstart
  Starting MongoDB Server...
  [root@localhost ~]# about to fork childprocess, waiting until server is ready for connections.
  forked process: 1287
  child process started successfully, parentexiting
  [root@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数据库过大的问题
  [root@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-626100-1-1.html 上篇帖子: MongoDB需要慎用local、admin数据库 下篇帖子: Mongodb参数介绍
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

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

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

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

扫描微信二维码查看详情

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


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


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


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



合作伙伴: 青云cloud

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