环境描述:有三台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,大家有兴趣可以看看

作者:lpj24
链接:https://www.jianshu.com/p/edff38a59967
來源:简书
简书著作权归作者所有,任何形式的转载都请联系作者获得授权并注明出处。

生产环境下搭建mongodb复制集高可用环境(python)的更多相关文章

  1. MongoDB复制集高可用选举机制(三)

    复制集高可用选举机制 在上一章介绍了MongoDB的架构,复制集的架构直接影响着故障切换时的结果.为了能够有效的故障切换,请确保至少有一个节点能够顺利升职为主节点.保证在拥有核心业务系统的数据中心中拥 ...

  2. MongoDB复制集原理、环境配置及基本测试详解

    一.MongoDB复制集概述 MongoDB复制集实现了冗余备份和故障转移两大功能,这样能保证数据库的高可用性.在生产环境,复制集至少包括三个节点,其中一个必须为主节点,一个从节点,一个仲裁节点.其中 ...

  3. Windows搭建MongoDB复制集

    ​上篇,我们已经知道了什么是MongoDB的复制集,不知道的可以查看上篇哦,传送门来了. 光说不练,假把式,咱来自己搭建一个复制集.先下载安装哦,不知道的查看上篇哦,https://blog.csdn ...

  4. mongodb副本集高可用架构

    一.简介 Mongodb复制集由一组Mongod实例(进程)组成,包含一个Primary节点和多个Secondary节点. Mongodb Driver(客户端)的所有数据都写入Primary,Sec ...

  5. Docker下搭建mongodb副本集

    背景 有需求需要对mongodb做一个容灾备份.根据官网,发现mongodb最新版本(4.0)已经抛弃了主从模式而采用副本集进行容灾.副本集的优势在于:"有自动故障转移和恢复特性,其任意节点 ...

  6. Centos下部署DRBD+NFS+Keepalived高可用环境记录

    使用NFS服务器(比如图片业务),一台为主,一台为备.通常主到备的数据同步是通过rsync来做(可以结合inotify做实时同步).由于NFS服务是存在单点的,出于对业务在线率和数据安全的保障,可以采 ...

  7. win10环境下搭建zookeeper伪集群

    一.下载zookeeper https://mirrors.tuna.tsinghua.edu.cn/apache/zookeeper/ 这里笔者下载的是zookeeper-3.3.6 二.配置zoo ...

  8. (转)CentOS7.4环境下搭建--Gluster分布式集群存储

    原文:https://blog.csdn.net/qq_39591494/article/details/79853038 环境如下:OS:Centos7.4x86_64IP地址如下: Daasban ...

  9. MongoDb复制集实现故障转移,读写分离

    前言 数据库技术是信息系统的一个核心技术,发展很快,各种功能类型数据库层出不穷,之前工作中使用过关系型数据库(mysql.oracle等).面相对象数据库(db4o).key-value存储(Memc ...

随机推荐

  1. Unity3D游戏开发之C#编程中常见数据结构的比较

    一.前言 Unity3D是如今最火爆的游戏开发引擎,它可以让我们能轻松创建诸如三维视频游戏.建筑可视化.实时三维动画等类型的互动内容.它支持2D/3D游戏开发,据不完全统计,目前国内80%的手机游戏都 ...

  2. codevs——1294 全排列

    1294 全排列  时间限制: 1 s  空间限制: 128000 KB  题目等级 : 黄金 Gold 题解  查看运行结果     题目描述 Description 给出一个n, 请输出n的所有全 ...

  3. android应用开发之View的大小计量单位(px、dpi、dp、dip、sp)

    http://blog.csdn.net/ljianhui/article/details/43601495?ref=myread 一.像素(px)与屏幕分辨率 1)px(Pixels ,像素):对应 ...

  4. 使用Myeclipse + SVN + TaoCode 免费实现项目版本控制的详细教程

    通过Myeclipse + SVN插件 + TaoCOde可以省去代码仓库的租建:同时还可以很好的满足小团队之间敏捷开发的需求.接下来详细介绍整个搭建流程. 首先,介绍所用到的工具: 1,Myecli ...

  5. tech blog link

    http://amitsaha.github.io/site/notes/index.html

  6. Android PullToRefresh 下拉刷新,上拉很多其它,支持ScrollView,ListView,可方便拓展GridView,WebView等

    在写着东西之前.从网上找到非常多这方面的源代码,可是基本没有找到惬意的.包含在GitHub上的比較有名的Android-PullToRefresh-master.思来想去还是自己写吧.当然当中借鉴了一 ...

  7. WMS8_仓库配置

    仓库划分为不同的区域,比如收货区,出货区,库存区,这些区域在odoo中称之为库位[location],库位可以上下嵌套,形成一个树状的层级关系. 库位分为不同的类型 物理库存位置[Physical s ...

  8. spring 事件模式 源代码导读

    一,jdk 事件对象基类 package java.util; import java.io.Serializable; public class EventObject implements Ser ...

  9. 【转载】5种网络IO模型

    同步(synchronous) IO和异步(asynchronous) IO,阻塞(blocking) IO和非阻塞(non-blocking)IO分别是什么,到底有什么区别?这个问题其实不同的人给出 ...

  10. 让Spring Boot启动更快

    关注公众号:锅外的大佬, 每日推送国外技术好文,帮助每位开发者更好成长 原文链接:https://dev.to/bufferings/lets-make-springboot-app-start-fa ...