首页 > 其他分享 >副本集replicaSet

副本集replicaSet

时间:2024-04-11 09:58:30浏览次数:33  
标签:副本 replicaSet 17 rs conf 节点 mongo

mongodb高可用架构

https://www.mongodb.com/docs/manual/tutorial/deploy-replica-set/

复制是跨多个服务器同步数据的过程。

复制提供冗余,并通过不同数据库服务器上的多个数据副本增加数据可用性。

复制保护数据库免受单个服务器的丢失。

复制还允许从硬件故障和服务中断中恢复。

使用其他数据副本,可以将其专用于灾难恢复,报告或备份。

为什么复制?

  • 保持数据安全
  • 数据的高可用性(24 * 7)
  • 灾难恢复
  • 维护无停机(如备份,索引重建,压缩)
  • 读取缩放(额外的副本可读)
  • 副本集对应用程序是透明的

副本集角色

主节点、读写
副本节点、同步主节点数据
仲裁节点、非必须、不存储数据,不竞主,只投票

什么是副本集

MongoDB通过使用副本集来实现复制。

副本集是托管相同数据集的一组 mongod 实例。

在一个副本中,一个节点是接收所有写操作的主节点。

所有其他实例(例如辅助节点)都应用主节点的操作,以便它们具有相同的数据集。

副本集可以只有一个主节点。

  • 副本集是一组两个或多个节点(通常最少需要3个节点)。
  • 在副本集中,一个节点是主节点,其余节点是次要节点。
  • 所有数据从主节点复制到辅助节点。
  • 在自动故障切换或维护时,选择为主节点建立,并选择新的主节点。
  • 恢复故障节点后,它再次加入副本集,并作为辅助节点。

显示了MongoDB复制的典型图,客户端应用程序始终与主节点进行交互,然后主节点将数据复制到辅助节点。

 

部署副本集



mkdir -p /opt/mongo_2801{7,8,9}/{conf,log,pid}  
mkdir -p /data/mongo_2801{7,8,9}

cat >/opt/mongo_28017/conf/mongodb.conf <<EOF
systemLog:
 destination: file   
 logAppend: true  
 path: /opt/mongo_28017/log/mongodb.log

storage:
 journal:
   enabled: true
 dbPath: /data/mongo_28017
 directoryPerDB: true
 wiredTiger:
    engineConfig:
       cacheSizeGB: 0.5 
       directoryForIndexes: true
    collectionConfig:
       blockCompressor: zlib
    indexConfig:
       prefixCompression: true

processManagement:
 fork: true
 pidFilePath: /opt/mongo_28017/pid/mongod.pid

net:
 port: 28017
 bindIp: 127.0.0.1,10.0.0.17

replication: # 开启主从复制
   oplogSizeMB: 1024  # 类似binlog日志的大小单位,1GB
   replSetName: dba   # 副本集名
EOF

# 复制3个实例,区分端口号
cp /opt/mongo_28017/conf/mongodb.conf /opt/mongo_28018/conf/
cp /opt/mongo_28017/conf/mongodb.conf /opt/mongo_28019/conf/

# 启动3个mongodb实例
sed -i 's#28017#28018#g' /opt/mongo_28018/conf/mongodb.conf
sed -i 's#28017#28019#g' /opt/mongo_28019/conf/mongodb.conf
mongod -f /opt/mongo_28017/conf/mongodb.conf
mongod -f /opt/mongo_28018/conf/mongodb.conf
mongod -f /opt/mongo_28019/conf/mongodb.conf


# 检查3个实例
ps -ef|grep mongo
netstat -lntup|grep mongo

登录mongo副本集

1. 修改配置文件,以副本集模式启动多实例

2. 初始化副本集 28017 作为主节点
https://www.mongodb.com/docs/manual/tutorial/deploy-replica-set/#initiate-the-replica-set


mongo --port 28017

# 只需要在一个节点执行,其他节点自动加入

rs.initiate(
   {
      _id: "dba",
      version: 1,
      members: [
         { _id: 0, host : "10.0.0.17:28017" },
         { _id: 1, host : "10.0.0.17:28018" },
         { _id: 2, host : "10.0.0.17:28019" }
      ]
   }
)

 

该方法是官网推荐的模式,存在选举时间

查看副本集状态

rs.status()
# rs是管理集群的命令

 

从库开启slve


不开启会提示报错,读的权限都没用,slave状态不正确

dba:SECONDARY> show dbs;
2022-10-17T17:11:47.201+0800 E  QUERY    [js] uncaught exception: Error: listDatabases failed:{
    "operationTime" : Timestamp(1665997900, 1),
    "ok" : 0,
    "errmsg" : "not master and slaveOk=false",
    "code" : 13435,
    "codeName" : "NotPrimaryNoSecondaryOk",
    "$clusterTime" : {
        "clusterTime" : Timestamp(1665997900, 1),
        "signature" : {
            "hash" : BinData(0,"AAAAAAAAAAAAAAAAAAAAAAAAAAA="),
            "keyId" : NumberLong(0)
        }
    }
} :
_getErrorWithCode@src/mongo/shell/utils.js:25:13
Mongo.prototype.getDBs/<@src/mongo/shell/mongo.js:147:19
Mongo.prototype.getDBs@src/mongo/shell/mongo.js:99:12
shellHelper.show@src/mongo/shell/utils.js:906:13
shellHelper@src/mongo/shell/utils.js:790:15
@(shellhelp2):1:1
dba:SECONDARY>

开启方式

echo "rs.slaveOk()" > ~/.mongorc.js

测试副本集

主库写入数据

dba:PRIMARY> db.myblog.insertOne({"website":"www.yuchaoit.cn"})
{
    "acknowledged" : true,
    "insertedId" : ObjectId("634d1c065705b0c66b18384a")
}
dba:PRIMARY> show dbs;
admin   0.000GB
config  0.000GB
local   0.000GB
test    0.000GB
dba:PRIMARY> db.myblog.find()
{ "_id" : ObjectId("634d1c065705b0c66b18384a"), "website" : "www.yuchaoit.cn" }
dba:PRIMARY>

从库只读权限

 

副本集常用命令

rs.config()
rs.status()
rs.isMaster()
dba:PRIMARY> rs.printReplicationInfo()
configured oplog size:   1024MB
log length start to end: 1430secs (0.4hrs)
oplog first event time:  Mon Oct 17 2022 16:53:20 GMT+0800 (CST)
oplog last event time:   Mon Oct 17 2022 17:17:10 GMT+0800 (CST)
now:                     Mon Oct 17 2022 17:17:13 GMT+0800 (CST)
dba:PRIMARY> 

查看从库信息
dba:PRIMARY> rs.printSlaveReplicationInfo()
WARNING: printSlaveReplicationInfo is deprecated and may be removed in the next major release. Please use printSecondaryReplicationInfo instead.
source: 10.0.0.17:28018
    syncedTo: Mon Oct 17 2022 17:17:20 GMT+0800 (CST)
    0 secs (0 hrs) behind the primary 
source: 10.0.0.17:28019
    syncedTo: Mon Oct 17 2022 17:17:20 GMT+0800 (CST)
    0 secs (0 hrs) behind the primary 
dba:PRIMARY> 

# 最新命令

dba:PRIMARY> rs.printSecondaryReplicationInfo()
source: 10.0.0.17:28018
    syncedTo: Mon Oct 17 2022 17:17:37 GMT+0800 (CST)
    0 secs (0 hrs) behind the primary 
source: 10.0.0.17:28019
    syncedTo: Mon Oct 17 2022 17:17:37 GMT+0800 (CST)
    0 secs (0 hrs) behind the primary 
dba:PRIMARY>

副本集故障转移

1. 关闭主库
[root chaoge-linux /data/mongo_27017]#mongod -f /opt/mongo_28017/conf/mongodb.conf --shutdown
killing process with pid: 9492

## 2.查看副本集信息
rs.status()
rs.config()

3.查看新的复制关系

 

新的主从关系

 

从库权重调整

了解即可

myconfig=rs.conf()
myconfig.members[0].priority=100  // 选择第几个成员,设置优先级
rs.reconfig(myconfig) // 重新加载配置

# 主动降级优先级,从主库,降到从库
rs.stepDown()

# 恢复配置
myconfig=rs.conf()
myconfig.members[0].priority=1
rs.reconfig(myconfig)

 

增加节点

增加节点和删除节点
1.创建新节点
mkdir -p /opt/mongo_28010/{conf,log,pid}  
mkdir -p /data/mongo_28010
cp /opt/mongo_28017/conf/mongodb.conf /opt/mongo_28010/conf/
sed -i 's#28017#28010#g' /opt/mongo_28010/conf/mongodb.conf 
mongod -f /opt/mongo_28010/conf/mongodb.conf
mongo --port 28010

2.集群加入新节点,只能在主库加
rs.add("10.0.0.17:28010")

3.删除节点
rs.remove("10.0.0.17:28010")

 

标签:副本,replicaSet,17,rs,conf,节点,mongo
From: https://www.cnblogs.com/sxy-blog/p/18128118

相关文章

  • Replication Controller、ReplicaSet和Deployment(Kubernetes调度系列,结合操作命令讲解
    目录一、概述二、ReplicationController2.1ReplicationController说明2.2ReplicationController举例三、ReplicaSet3.1ReplicaSet说明3.2ReplicaSet举例四、无状态应用管理Deployment4.1概述4.2创建Deployment4.2.1Deployment标签内容解析4.2.2ku......
  • Adobe InCopy 2024 v19.3 (macOS, Windows) - 编写和副本编辑软件
    AdobeInCopy2024v19.3(macOS,Windows)-编写和副本编辑软件Acrobat、AfterEffects、Animate、Audition、Bridge、CharacterAnimator、Dimension、Dreamweaver、Illustrator、InCopy、InDesign、LightroomClassic、MediaEncoder、Photoshop、PremierePro、AdobeXD......
  • 接口,多态性,深层和浅层副本,密封类和异常。
    C#接口遥控器是观众和电视之间的接口。它是此电子设备的接口。外交礼仪指导外交领域的所有活动。道路规则是驾车者,骑自行车者和行人必须遵守的规则。编程中的接口类似于前面的示例。接口是:APIsContracts对象通过其公开的方法与外界交互。实际的实现对程序员而言并不......
  • 分区和副本机制
    生产者分区写入策略生产者写入消息到topic,Kafka将依据不同的策略将数据分配到不同的分区中轮询分区策略随机分区策略按key分区分配策略自定义分区策略轮询策略默认的策略,也是使用最多的策略,可以最大限度保证所有消息平均分配到一个分区 如果在生产消息时,key为null,则使用......
  • [Kubernetes] ReplicaSet
    DefineaReplicaSet:AReplicaSetisaKubernetescontrollerresponsibleforensuringaspecifiednumberofpodreplicasarerunningatalltimes.Itmaintainsthedesiredstateofpodsbycreatingordeletingreplicasasnecessary.ReplicaSetshelpinsc......
  • mongoDB使用记录:副本集选举淘汰策略失效
    一个问题场景:业务请求查询数据库,当请求没有成功返回时(这里是数据库机器异常,表现是不返回请求结果,处于假死状态),业务挂起进入等待(WAIT),逻辑中断,表现为卡顿、持续加载中;高并发场景下,短时间内堆积的请求会大量占用发起数据库请求的机器的内存(风险一),大量业务卡顿异常;当数据库异常解决成......
  • RocketMQ搭建(单组节点单副本模式)
    RocketMQ搭建(单组节点单副本模式) 1、下载RocketMQ二进制包wgethttps://archive.apache.org/dist/rocketmq/5.1.2/rocketmq-all-5.1.2-bin-release.zip 2、解压,移动程序包至安装目录并创建软连接。unziprocketmq-all-5.1.2-bin-release.zipmvrocketmq-all-5.1.2-b......
  • MySQL中复制表(创建表的副本、备份表)
    1.第一种复制表结构和数据--复制表的结构和数据,但是不会复制表的约束、外键、触发器、索引等createtabletest_duplicationasselect*fromtest;--此处的as可以省略2.第二种只复制表的结构createtabletest_duplicationasselect*fromtestwhere1=0;--此......
  • h5 canvas 视频透明度抠图,视频需要一个灰度通道副本表示透明度
    视频透明度抠图,视频需要一个灰度通道副本表示透明度目前抖音等直播平台的礼物特效就是这个方法处理的 <!DOCTYPEhtml><html><head><metacharset="UTF-8"><title>视频灰度通道抠图,视频包含灰度值表示透明的副本</title><style>html,body{ ::-......
  • 使用单机部署为副本集(开启oplog.rs)-4.4.13
    环境:OS:Centos7db:4.4.131.下载相应的版本https://www.mongodb.com/download-center/community我这里下载的是mongodb-linux-x86_64-rhel70-4.4.13.tgz 2.创建安装目录[root@testservices]#mkdir-p/usr/local/services[root@testservices]#mkdir-p/home/middle/mong......