美文网首页知曰Pythoner集中营python自学
生产环境下搭建mongodb复制集高可用环境(python)

生产环境下搭建mongodb复制集高可用环境(python)

作者: lpj24 | 来源:发表于2015-02-13 15:45 被阅读1880次

环境描述:有三台ubuntu服务器,,每台服务器上已经有mongodb实例。创建3个mongo2.4的新实例,分别作为三个复制集节点,同时保证了当前单节点环境的稳定

3台服务器都已经有单个mongo实例运行

步骤

1.创建mongo新实例需要的目录资源   主要是数据库存放目录、日志文件、配置文件、key文件(保证节点通信)  

  文件可以在任何地方创建,我在/usr/local下的创建mongodb_rs作为新实例的目录,在该目录下创建资源目录

  1.数据库  mkdir db

  2.日志文件  mkdir log 

  3.配置文件  touch rs.conf  可以cat /etc/mongodb.conf>rs.conf初始化,添加或修改下面几项

port = 29010             #更改端口 先lsof -i:29010查看是否被占用

fork=true                   #后台demon进程运行

journal=true              #启用可靠性日志

oplogSize=2048  

smallfiles=true

replSet=test_rs         #复制集名称

keyFile=/usr/local/mongodb_rs/key.key   #复制集通信key

4.key文件  touch key.key  生成秘钥 openssl rand 888 -base64>key.key  用888不要太长 key的长度是有限制的

好了  目前目录资源都已经创建,先不启动。在其它2个节点重复以上过程,当然第4步用重复,把第一台上的key.key文件内容复制到每一个节点的key.key文件下

在每一台服务节点启动mongo的新实例(mongodb_rs目录下)  mongod -f rs.conf 稍等一会儿会提示successful  如果不成功查看rs.log日志文件查找原因,可能更换一下端口号

2.配置复制集 

    选一台服务节点作为primary库192.168.1.132,在服务器上连接mongod实例mongo --port=29010

    1.初始化复制集  rs.initiate()  查看rs.conf()  正常情况下生成了一个节点hostname:29010

       这个hostname是主机名,把这个主机名添加到另外2台节点的/etc/hosts文件里面

    2.添加节点  

      rs.add("192.168.1.133:29010")

      rs.add("192.168.1.134:29010")

   3.设置优先级,当主节点当机之后重启的时候任然能成为primary节点,一个节点为0  不会成为主节点

    cfg = rs.conf()

    cfg.members[0].priority=3

    cfg.members[1].priority=1

    cfg.members[0].priority=0

      重新加载

     rs.reconfg(cfg)

   4.查看各个节点的状态 (当然你可以先退出 在登录查看状态)

     health:1  #正常状态

    "stateStr" : "PRIMARY"   #标识主节点

STARTUP:刚加入到复制集中,配置还未加载

STARTUP2:配置已加载完,初始化状态

 RECOVERING:正在恢复,不适用读

ARBITER: 仲裁者

DOWN:节点不可到达

UNKNOWN:未获取其他节点状态而不知是什么状态,一般发生在只有两个成员的架构,脑裂

REMOVED:移除复制集

ROLLBACK:数据回滚,在回滚结束时,转移到RECOVERING或SECONDARY状态

FATAL:出错。查看日志grep “replSet FATAL”找出错原因,重新做同步

PRIMARY:主节点

SECONDARY:备份节点

   5.为数据库创建用户名和密码  保证程序任何情况下(主库挂了)访问一个可靠的库  如为app库创建一个账号

     use app

    db.addUser("test","123")

   

3.测试数据同步  主从切换

     1.完成了配置之后  先看看secondary是否同步了主库的数据   或者kill主库的mongo进程  等待一会儿看看是否主库发生了切换   然后重启看主库是不是重新成为了主库

4.使用pymongo连接mongodb数据库 

import pymongo

client=pymongo.MongoClient("192.168.1.132:29010",replicaSet="test_rs")

db = client["app"]

db.authenticate('test','123')

db.user.find()

db.connection.host  #打印当前连接服务器


使用pymongo连接数据库之后可以测试   ,当kill主库之后  再次打印db.connection.host看看是否还是上次那个host   如果不同说明故障转移了

5.如果要做读写分离,设置从库可读,pymongo也提高了这样的api,大家有兴趣可以看看

相关文章

  • 生产环境下搭建mongodb复制集高可用环境(python)

    环境描述:有三台ubuntu服务器,,每台服务器上已经有mongodb实例。创建3个mongo2.4的新实例,分别...

  • MongoDB复制集环境搭建

    PSS(推荐) PSA 复制集架构 环境准备 版本4.4.9端口28017/28018/28019 初始化环境(用...

  • MongoDB复制集部署

    MongoDB的高可用特使是用复制集实现的,本文介绍如何在CentOS7快速搭建一个复制集 部署单节点版本 yum...

  • MongoDB:3.分片集群

    环境 MongoDB分片群集包含以下组件: 生产环境配置 在生产群集中,确保数据冗余并确保系统具有高可用性。对于生...

  • mongodb——分布式

    复制集 mongodb在集群环境中,通过复制的形式对数据进行冗余。mongodb复制集有Primary、Secon...

  • 2019-10-12

    利用LVS+Keepalived搭建Mysql双主复制高可用负载均衡环境 应用背景: MySQL复制(主主,主从....

  • 生产环境搭建高可用Harbor

    前言 因资源成本问题,本Harbor高可用架构为最小开销方案,如果资源充足,可以将PG、Redis全部使用使用云厂...

  • 【MongoDB高可用】复制集Replica Set使用简介

    MongoDB高可用 对于MongoDB,可以支持使用单机模式提供服务,但是在实际的生产环境中,单机模式将面临很大...

  • mongodb工作模式

    单机版 主要用来开发和测试,一般不用于生产环境 复制集 目的 主要为了高可用,可以failover 读写分离,读可...

  • MongoDB之一 hello world

    使用python搭建一个学习mongoDB的环境首先安装各种软件,包括mongoDB 3.4,python2.7,...

网友评论

    本文标题:生产环境下搭建mongodb复制集高可用环境(python)

    本文链接:https://www.haomeiwen.com/subject/yugsxttx.html