生产环境下搭建mongodb复制集高可用环境(python)
环境描述:有三台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)的更多相关文章
- MongoDB复制集高可用选举机制(三)
复制集高可用选举机制 在上一章介绍了MongoDB的架构,复制集的架构直接影响着故障切换时的结果.为了能够有效的故障切换,请确保至少有一个节点能够顺利升职为主节点.保证在拥有核心业务系统的数据中心中拥 ...
- MongoDB复制集原理、环境配置及基本测试详解
一.MongoDB复制集概述 MongoDB复制集实现了冗余备份和故障转移两大功能,这样能保证数据库的高可用性.在生产环境,复制集至少包括三个节点,其中一个必须为主节点,一个从节点,一个仲裁节点.其中 ...
- Windows搭建MongoDB复制集
上篇,我们已经知道了什么是MongoDB的复制集,不知道的可以查看上篇哦,传送门来了. 光说不练,假把式,咱来自己搭建一个复制集.先下载安装哦,不知道的查看上篇哦,https://blog.csdn ...
- mongodb副本集高可用架构
一.简介 Mongodb复制集由一组Mongod实例(进程)组成,包含一个Primary节点和多个Secondary节点. Mongodb Driver(客户端)的所有数据都写入Primary,Sec ...
- Docker下搭建mongodb副本集
背景 有需求需要对mongodb做一个容灾备份.根据官网,发现mongodb最新版本(4.0)已经抛弃了主从模式而采用副本集进行容灾.副本集的优势在于:"有自动故障转移和恢复特性,其任意节点 ...
- Centos下部署DRBD+NFS+Keepalived高可用环境记录
使用NFS服务器(比如图片业务),一台为主,一台为备.通常主到备的数据同步是通过rsync来做(可以结合inotify做实时同步).由于NFS服务是存在单点的,出于对业务在线率和数据安全的保障,可以采 ...
- win10环境下搭建zookeeper伪集群
一.下载zookeeper https://mirrors.tuna.tsinghua.edu.cn/apache/zookeeper/ 这里笔者下载的是zookeeper-3.3.6 二.配置zoo ...
- (转)CentOS7.4环境下搭建--Gluster分布式集群存储
原文:https://blog.csdn.net/qq_39591494/article/details/79853038 环境如下:OS:Centos7.4x86_64IP地址如下: Daasban ...
- MongoDb复制集实现故障转移,读写分离
前言 数据库技术是信息系统的一个核心技术,发展很快,各种功能类型数据库层出不穷,之前工作中使用过关系型数据库(mysql.oracle等).面相对象数据库(db4o).key-value存储(Memc ...
随机推荐
- BZOJ 4034 [HAOI2015]树上操作(树链剖分)
题目链接 BZOJ4034 这道题树链剖分其实就可以了. 单点更新没问题. 相当于更新 [f[x], f[x]]这个区间. f[x]表示树链剖分之后每个点的新的标号. 区间更新的话类似DFS序,求出 ...
- shell高级-----初识sed和gawk
sed编辑器 sed说明 sed是Linux下一款功能强大的非交互流式文本编辑器,可以对文本文件进行增.删.改.查等操作,支持按行.按字段.按正则匹配文本内容,灵活方便,特别适合于大文件的编辑. 替换 ...
- Spark学习(一) Spark初识
一.官网介绍 1.什么是Spark 官网地址:http://spark.apache.org/ Apache Spark™是用于大规模数据处理的统一分析引擎. 从右侧最后一条新闻看,Spark也用于A ...
- 识别SQL Server 性能杀手
性能优化的重点在于识别定位问题,预先了解主要的性能杀手,能够更快的定位到问题并将工作集中在可能的原因之上. SQL SERVER性能杀手主要集中在如下几类: 1.1 低质量的索引 低质量的索引通常 ...
- pinpoint 应用性能管理工具安装部署
原文:http://www.cnblogs.com/yyhh/p/6106472.html pinpoint 安装部署 阅读目录 1. 环境配置 1.1 获取需要的依赖包 1.2 配置jdk1.7 ...
- 大众车机天宝187A Hack笔记
0×00前言 自从去年买了车,对汽车电子系统的兴趣就上来了.这不,前一阵子逛汽车论坛,发现了有网友将老版本的天宝车机被刷上了2017新帕萨特车机的系统,支持超级蓝牙和苹果CarPlay,百度CarLi ...
- 391. Perfect Rectangle
最后更新 一刷 16-Jan-2017 这个题我甚至不知道该怎么总结. 难就难在从这个题抽象出一种解法,看了别人的答案和思路= =然而没有归类总结到某种类型,这题相当于背了个题... 简单的说,除了最 ...
- poj2482--Stars in Your Window(扫描线)
题目链接:点击打开链接 链接题目大意:给出n个星星的坐标,每一个星星有一个亮度.给出一个矩形的长和宽,问矩形能包含的星星的最大亮度和(不包含边框). 如果每个星星都是矩形的最左下点.那么每个星星都能够 ...
- js中有包装类,java中也有包装类
new Number() vs Number() What is the difference between new Number() and Number()? I get that new Nu ...
- [转]通俗易懂的php多线程解决方案
原文: https://www.w3cschool.cn/php/php-thread.html --------------------------------------------------- ...