副本集的搭建

创建多实例目录

[root@redis03 ~]# mkdir /server/mongodb/2801{7,8,9}/{conf,logs,pid,data} -p

编辑多实例配置文件

[root@redis03 ~]# vim /server/mongodb/28017/conf/mongo.conf
systemLog:
destination: file
logAppend: true
path: /server/mongodb/28017/logs/mongodb.log
#path: /server/mongodb/28018/logs/mongodb.log
#path: /server/mongodb/28019/logs/mongodb.log storage:
journal:
enabled: true
dbPath: /server/mongodb/28017/data
#dbPath: /server/mongodb/28018/data
#dbPath: /server/mongodb/28019/data
directoryPerDB: true
wiredTiger:
engineConfig:
cacheSizeGB: 1
directoryForIndexes: true
collectionConfig:
blockCompressor: zlib
indexConfig:
prefixCompression: true processManagement:
fork: true
pidFilePath: /server/mongodb/28017/pid/mongod.pid
#pidFilePath: /server/mongodb/28018/pid/mongod.pid
#pidFilePath: /server/mongodb/28019/pid/mongod.pid net:
port: 28017
#port: 28018
#port: 28019
bindIp: 127.0.0.1,172.16.1.121 replication:
#类似于binlog,指定大小
oplogSizeMB: 1024
#副本记得名称,集群名称
replSetName: dba

启动多实例

[root@redis03 ~]# chown -R mongo.mongo /server/mongodb/
[root@redis03 ~]# su - mongo [mongo@redis03 ~]$ mongod -f /server/mongodb/28017/conf/mongo.conf
[mongo@redis03 ~]$ mongod -f /server/mongodb/28018/conf/mongo.conf
[mongo@redis03 ~]$ mongod -f /server/mongodb/28019/conf/mongo.conf #验证
[mongo@redis03 ~]$ netstat -lntp
tcp 0 0 172.16.1.121:27017 0.0.0.0:* LISTEN 20881/mongod
tcp 0 0 127.0.0.1:27017 0.0.0.0:* LISTEN 20881/mongod
tcp 0 0 172.16.1.121:28017 0.0.0.0:* LISTEN 328121/mongod
tcp 0 0 127.0.0.1:28017 0.0.0.0:* LISTEN 328121/mongod
tcp 0 0 172.16.1.121:28018 0.0.0.0:* LISTEN 321218/mongod
tcp 0 0 127.0.0.1:28018 0.0.0.0:* LISTEN 321218/mongod
tcp 0 0 172.16.1.121:28019 0.0.0.0:* LISTEN 32981/mongod
tcp 0 0 127.0.0.1:28019 0.0.0.0:* LISTEN 32981/mongod

登录多实例

[mongo@redis03 ~]$ mongo  172.16.1.121:28017
[mongo@redis03 ~]$ mongo 172.16.1.121:28018
[mongo@redis03 ~]$ mongo 172.16.1.121:28019

初始化副本集

#配置副本集
config = {
_id : "dba",
members : [
{_id:0, host:"172.16.1.121:28017"},
{_id:1, host:"172.16.1.121:28018"},
{_id:2, host:"172.16.1.121:28019"},
]
} #读取副本集
rs.initiate(config)

查看副本集状态

dba:PRIMARY> rs.status()
# 健康状态 1表示正常 0表示故障
"health" : 1,
# 表示状态 1是主库 2是从库 3表示恢复数据中 7表示投票者 8表示down机
"state" : 1,
# 标注是主库还是从库
"stateStr" : "PRIMARY",
# 集群启动时间
"uptime" : 579,
# 另一种格式的时间
"optime" : {
"ts" : Timestamp(15905121779, 1),
"t" : NumberLong(1)
},
# 上一次心跳传过来数据的时间
"optimeDate" : ISODate("2020-05-27T15:36:19Z"),
# 检测上一次心跳时间
"lastHeartbeat" : ISODate("2020-05-27T15:36:25.815Z"), #查看集群与主节点
dba:PRIMARY> rs.isMaster() #oplog信息
dba:PRIMARY> rs.printReplicationInfo()
configured oplog size: 1024MB
log length start to end: 1543secs (0.43hrs)
oplog first event time: Wed May 27 2020 23:26:46 GMT+0800 (CST)
oplog last event time: Wed May 27 2020 23:52:29 GMT+0800 (CST)
now: Wed May 27 2020 23:52:38 GMT+0800 (CST) #查看延时从库信息
dba:PRIMARY> rs.printSlaveReplicationInfo()
source: 10.0.0.121:28018
syncedTo: Wed May 27 2020 23:54:19 GMT+0800 (CST)
0 secs (0 hrs) behind the primary
source: 10.0.0.121:28019
syncedTo: Wed May 27 2020 23:54:19 GMT+0800 (CST)
0 secs (0 hrs) behind the primary #打印副本集配置文件
dba:PRIMARY> rs.config()

主库创建数据,从库查看数据

# 主库插入数据
db.table.insertMany([{"name":"gcc","age":10},{"name":"zzy","age":9},{"name":"hxh","age":11}])
# 主库查看数据
dba:PRIMARY> show tables
table
dba:PRIMARY> db.table.find() # 从库查看数据
dba:SECONDARY> show databases
2020-05-27T23:43:40.020+0800 E QUERY [thread1] Error: listDatabases failed:{
"operationTime" : Timestamp(1590594219, 1),
"ok" : 0,
"errmsg" : "not master and slaveOk=false",
"code" : 13435,
"codeName" : "NotMasterNoSlaveOk",
"$clusterTime" : {
"clusterTime" : Timestamp(1590594219, 1),
"signature" : {
"hash" : BinData(0,"AAAAAAAAAAAAAAAAAAAAAAAAAAA="),
"keyId" : NumberLong(0)
}
}
}
# 连查看库都会被拒绝,因为从库不提供读写 # 执行命令(从库都要执行)
dba:SECONDARY> rs.slaveOk()
dba:SECONDARY> show databases
admin 0.000GB
cluster 0.000GB
config 0.000GB
local 0.000GB # 每次重新连接都要执行以上命令才能读取
# 可以配置永久生效
[root@redis03 ~]# vim ~/.mongorc.js
rs.slaveOk()

副本集实现高可用

故障切换测试

# 主库使用 localhost 连接,执行关闭数据库的操作(使用 ip 连接是不能执行的)
[mongo@redis03 ~]$ mongo localhost:28017
dba:PRIMARY> use admin
switched to db admin
dba:PRIMARY> db.shutdownServer() # 查看其他从库中会有一台从库,变成主库 # 故障转移实现了,但是我的程序连接 mongodb 的配置还需要修改怎么办??

程序怎么实现连接切换的

1.如果使用的是单节点,那么程序里面直接配置写死mongodb的 ip 和端口即可

2.如果是副本集集群的形式,在程序里面写的就是一个列表,列表里面写
mongo_reip = [172.16.1.121:28017,172.16.1.121:28018,172.16.1.121:28019]
程序会去使用命令询问谁是主节点,得到结果后在写入数据

恢复主库

#重新启动主库,他会自动判断谁是主库,自动成为新的从库

注意:三台节点,只能坏一台,坏两台就有问题了

指定节点提升优先级

# 原来的主库配置高,性能好,想恢复之后还让他是主库怎么办

# 查看优先级
dba:PRIMARY> rs.conf()
# 权重值
"priority" : 1, # 临时修改配置文件
dba:PRIMARY> config=rs.conf()
# 修改配置文件中 id 为 0 的priority值为 10
dba:PRIMARY> config.members[0].priority=10
# 配置文件生效
dba:PRIMARY> rs.reconfig(config) # 新版本调整完直接切换主库,旧版本需要主动降级
dba:PRIMARY> rs.stepDown() # 恢复权重
dba:PRIMARY> config=rs.conf()
dba:PRIMARY> config.members[0].priority=1
dba:PRIMARY> rs.reconfig(config)

扩容与删减节点

配置一台新的节点

# 创建目录
[root@redis03 ~]# mkdir /server/mongodb/28016/{conf,logs,pid,data} -p # 配置新节点
[root@redis03 ~]# cp /server/mongodb/28017/conf/mongo.conf /server/mongodb/28016/conf/
[root@redis03 ~]# sed -i 's#28017#28016#g' /server/mongodb/28016/conf/mongo.conf # 启动新节点
[root@redis03 ~]# chown -R mongo.mongo /server/mongodb/
[root@redis03 ~]# su - mongo
[mongo@redis03 ~]$ mongod -f /server/mongodb/28016/conf/mongo.conf

将新节点加入集群

#主库操作
dba:PRIMARY> rs.add("172.16.1.121:28016")
{
"ok" : 1,
"operationTime" : Timestamp(1590597530, 1),
"$clusterTime" : {
"clusterTime" : Timestamp(1590597530, 1),
"signature" : {
"hash" : BinData(0,"AAAAAAAAAAAAAAAAAAAAAAAAAAA="),
"keyId" : NumberLong(0)
}
}
} # 查看集群状态
dba:PRIMARY> rs.status() # 注意:四个节点也不能坏两台机器

删除节点

# 主库操作
dba:PRIMARY> rs.remove("172.16.1.121:28016")
{
"ok" : 1,
"operationTime" : Timestamp(1590597842, 1),
"$clusterTime" : {
"clusterTime" : Timestamp(1590597842, 1),
"signature" : {
"hash" : BinData(0,"AAAAAAAAAAAAAAAAAAAAAAAAAAA="),
"keyId" : NumberLong(0)
}
}
} # 查看集群状态
dba:PRIMARY> rs.status()

添加仲裁节点

# 创建目录
[root@redis03 ~]# mkdir /server/mongodb/28015/{conf,logs,pid,data} -p # 配置新节点
[root@redis03 ~]# cp /server/mongodb/28017/conf/mongo.conf /server/mongodb/28015/conf/
[root@redis03 ~]# sed -i 's#28017#28015#g' /server/mongodb/28015/conf/mongo.conf # 启动新节点
[root@redis03 ~]# chown -R mongo.mongo /server/mongodb/
[root@redis03 ~]# su - mongo
[mongo@redis03 ~]$ mongod -f /server/mongodb/28015/conf/mongo.conf # 主库操作加入仲裁节点
dba:PRIMARY> rs.addArb(("10.0.0.121:28015") # 查看该库是否有数据 # 注意,五个节点时,可以坏两个节点

MongoDB 副本集搭建 & 副本集扩容的更多相关文章

  1. MongoDB Sharding(二) -- 搭建分片集群

    在上一篇文章中,我们基本了解了分片的概念,本文将着手实践,进行分片集群的搭建 首先我们再来了解一下分片集群的架构,分片集群由三部分构成: mongos:查询路由,在客户端程序和分片之间提供接口.本次实 ...

  2. Mongodb副本集搭建经验

    一.环境配置经验 1.一般安装的副本集的时候,主实例可以有数据库和用户:从实例不能.仲裁机不能有任何数据库包括用户 2.搭建副本集的时候Host使用外网IP,否则使用Mongodb VUE 1.6.9 ...

  3. MongoDB副本集搭建及备份恢复

    一.MongoDB副本集(repl set)介绍 早起版本使用master-slave,一主一从和MySQL类似,但slave在此架构中为只读,当主库宕机后,从库不能自动切换为主: 目前已经淘汰了ma ...

  4. MongoDb的副本集搭建教程(个人操作笔记)

    很多公司都在用MongoDb ,一直没有时间研究,最近好好的整了一下,做下笔记,直接上操作步骤,关于Mongodb的理论知识可以搜索其他资料,也可以联系我索取 mongoDB官方已经不建议使用主从模式 ...

  5. MongoDB集群搭建-副本集

    MongoDB集群搭建-副本集 概念性的知识,可以参考本人博客地址: 一.Master-Slave方案: 主从: 二.Replica Set方案: 副本集: 步骤:(只要按步骤操作,100%成功) 1 ...

  6. mongodb副本集搭建过程中的问题和解决技巧

    在我以往的认知中,一个系统一旦正式上线,多半不会轻易的迁移服务器,尤其是那种涉及到多个关联应用,涉及到多台硬件服务器的系统,因为这种迁移将是牵一发而动全身的. 但是,却仍然有这种情况存在,就如我这几天 ...

  7. mongodb安装及副本集搭建

    mongodb下载地址:https://www.mongodb.com/dr/fastdl.mongodb.org/linux/mongodb-linux-x86_64-rhel62-3.2.7.tg ...

  8. MongoDB 3.4 高可用集群搭建(二)replica set 副本集

    转自:http://www.lanceyan.com/tech/mongodb/mongodb_repset1.html 在上一篇文章<MongoDB 3.4 高可用集群搭建(一):主从模式&g ...

  9. mongodb配置副本集(多台服务器间的副本集搭建) replica[ˈrɛplɪkə]

    副本集具有多个副本保证了容错性,就算一个副本挂掉了还有很多副本存在,并且解决了“主节点挂掉了,整个集群内会自动切换”的问题.我们来看看mongoDB副本集的架构图: 由图可以看到客户端连接到整个副本集 ...

随机推荐

  1. uni-app开发经验分享八: 实现微信APP支付的全过程详解

    背景 最近项目使用uni-app实现微信支付,把过程简单记录下,帮助那些刚刚基础uni-app,苦于文档的同学们.整体来说实现过程和非uni-app的实现方式没有太大不同,难点就在于uni-app对于 ...

  2. secrets 管理工具 Vault 的介绍、安装及使用

    原文:https://ryan4yin.space/posts/expirence-of-vault/ Vault 是 hashicorp 推出的 secrets 管理.加密即服务与权限管理工具.它的 ...

  3. redis修改requirepass 参数 改密码

    1. 不重启redis如何配置密码? a. 在配置文件中配置requirepass的密码(当redis重启时密码依然有效). # requirepass foobared  ->  修改成 :  ...

  4. 解决Linux下mysql区分大小写的问题

    1.查看lower_case_table_names的值,0代表区分大小写,1代表不区分大小写. 通过命令:SHOW VARIABLES LIKE 'lower%'; 1. 解决方法 以root用户登 ...

  5. (Sql Server)SQL FOR XML

    摘要:sql中的for xml语法为表转化为xml提供了很好的支持,当然使用同样的程序语言也能够达到同样的效果,但是有了for xml将使得这一切更加的方便. 主要内容: Select 的查询结果会作 ...

  6. Java 字符串简介

    从概念上讲,Java 字符串就是 Unicode 字符序列.Java 没有内置的字符串类型,而是在标准 Java 类库中提供了一个预定义类,很自然地叫做 String.每个用双引号括起来的字符串都是 ...

  7. 阿里云服务器centos7,docker部署mysql+Redis+vue+springboot+Nginx+fastdfs,亲测可用

    一.购买云服务器 我是今年双十一期间在阿里云购买的服务器, 简单配置2核_4G_40G_3M,三年用了不到800块,不过当时我记得腾讯云更便宜,个人感觉,阿里的云服务器更加的稳定, 毕竟身经百战, 经 ...

  8. 从一片森林(JavaScript)到另一片森林(C++)

    从JavaScript到C Plus Plus 作为一个忠诚的Web开发者,JavaScript几乎是我这一年多以来的首选,不管是开发网站后端服务,还是开发跨端应用,我都会首选一个使用JavaScri ...

  9. mysql数据恢复:.frm和.ibd,恢复表结构和数据

    mysql数据恢复:.frm和.ibd,恢复表结构和数据 一.恢复表结构 二.恢复表数据 相关内容原文地址: CSDN:她说巷尾的樱花开了:mysql根据.frm和.ibd文件恢复表结构和数据 博客园 ...

  10. Nginx基本功能及其原理,配置原理

    Nginx基本功能及其原理,配置原理 一.正向代理.反向代理 二.Nginx配置文件的整体结构 三.Nginx配置SSL及HTTP跳转到HTTPS 四.nginx 配置管理 [nginx.conf 基 ...