Mongodb负载均衡与备份方案的详细介绍
admin
2023-04-14 01:21:23
0

下文给大家带来Mongodb负载均衡与备份方案的详细介绍,希望能够给大家在实际运用中带来一定的帮助,负载均衡涉及的东西比较多,理论也不多,网上有很多书籍,今天我们就用在行业内累计的经验来做一个解答。

Mongodb负载均衡与备份方案

一、 路由负载均.............................................................................................. 1

二、 备份策略.......................................................................................................... 3

1.               增量备份(添加延迟备份节点)...................................................................... 3

2.               利用延迟备份节点恢复数据......................................................................... 4

3.               全量备份(添加延迟备份节点)...................................................................... 5

三、         其他问题..................................................................................................... 5

 Mongodb负载均衡与备份方案的详细介绍

一、路由负载均衡

采用appServer方式进行负载,因为Mongodb的路由(mongos)本身不支持负载均衡,MongoDB都是长链接, lvs会话时间一到,重新选择rs的时候,就有可能断掉之前的链接,就会出现104错误。

Mongodb负载均衡与备份方案的详细介绍


二、备份策略

 

Mongodb负载均衡与备份方案的详细介绍

1.    增量备份(添加延迟备份节点)

1)     利用另外一台secondary从机器传送数据

2)     在新机器上中配置文件中添加fastsync=true配置(当需要从有数据中启动节点,那么必须加上fastsync=true否则启动会报错,如果是从主库直接同步所有数据,那么就不需要添加这个参数)

3)     启动后,在primary节点中添加节点,如:rs.add("10.168.0.102:17017") 当我们看到变为secondary后,就一切正常,可以正常提供线上服务了

4)     通过rs.conf()命令查看现在的节点信息(需要admin库密码权限)

5)     rs.remove("10.168.0.102:17017")删除节点

6)     添加arbiter节点:rs.addArb("10.73.24.171:19003")

7)     添加延时备份机器:

        rs.add({_id:5,host:"10.168.0.102:17017",priority:0,slaveDelay:300});

rs.add({_id:5,host:"10.168.0.102:17018",priority:0,slaveDelay:300});

rs.add({_id:5,host:"10.168.0.102:17019",priority:0,slaveDelay:300});

注意:slaveDelay单位秒.

8)     出现这个错误时:replSet error RS102 too stale to catch up,我们可以db.printReplicationInfo()查看主库、从库的oplog信息

2.    利用延迟备份节点恢复数据

1)     先把延迟备份节点的数据,备份到各节点的master机子上。如:

#./mongodump -h 192.168.136.14:17017 -d UserInfoDB -o /data/mongoback/

#./mongodump -h 192.168.136.15:17018 -d UserInfoDB -o /data/mongoback/

#./mongodump -h 192.168.136.16:17019 -d UserInfoDB -o /data/mongoback/

2)     把备份的数据导入到个节点的master上。如:

建议先修复下,压缩空间

db.repairDatabase();修复数据(和压缩(删除数据)空间)

./mongorestore -h 127.0.0.1:17017 --directoryperdb /data/mongoback --drop --indexesLast

./mongorestore -h 127.0.0.1:17018 --directoryperdb /data/mongoback --drop --indexesLast

./mongorestore -h 127.0.0.1:17019 --directoryperdb /data/mongoback --drop --indexesLast

3.    全量备份

1)    写好脚本定期凌晨备份数据,如:

./mongodump -h 10.168.0.187:10000 -d UserInfoDB -o /data/mongoback/

2)    恢复数据

3)    建议先修复下,压缩空间

4)    db.repairDatabase();修复数据(和压缩(删除数据)空间)

./mongorestore -h 10.168.0.187:10000 --directoryperdb /data/mongoback --drop --indexesLast

三、其他问题

1.      如果启动不成功,则尝试修复.如:

./mongod --port 27017 --repair --dbpath /data/database/shard1/

2.      如果master节点kill了,则起来之后通过rs.stepDown(100)让出master的位置。

 

看了以上关于Mongodb负载均衡与备份方案的详细介绍,如果大家还有什么地方需要了解的可以在行业资讯里查找自己感兴趣的或者找我们的专业技术工程师解答的,技术工程师在行业内拥有十几年的经验了。



相关内容

热门资讯

【第一财经】“海贝大厅炸/金/... 【第一财经】“海贝大厅炸/金/花有挂吗?”(透视曝光猫腻)您好,海贝大厅炸/金/花这个游戏其实有挂的...
【今日要闻】“微友江西麻将辅助... 【今日要闻】“微友江西麻将辅助器?”(太坑了果然有挂)您好,微友江西麻将这个游戏其实有挂的,确实是有...
终于懂了“丫丫衡阳字牌究竟有挂... 终于懂了“丫丫衡阳字牌究竟有挂吗?”(原来真的有挂)您好,丫丫衡阳字牌这个游戏其实有挂的,确实是有挂...
今日重大消息“越记乡游到底是不... 网上科普关于“越记乡游有没有挂”话题很是火热,小编也是针对越记乡游作*弊开挂的方法以及开挂对应的知识...
我来教教您“杭州麻将有没有挂?... 有 亲,根据资深记者爆料杭州麻将是可以开挂的,确实有挂(咨询软件无需打开...
今日重大发现“蜀渝牌乐汇开挂神... 您好:蜀渝牌乐汇这款游戏可以开挂,确实是有挂的,需要了解加客服微信【4282891】很多玩家在这款游...
今日重磅消息“瓜瓜丰城棋牌有挂... 网上科普关于“瓜瓜丰城棋牌有没有挂”话题很是火热,小编也是针对瓜瓜丰城棋牌作*弊开挂的方法以及开挂对...
终于了解“么么棋牌究竟有挂吗?... 家人们!今天小编来为大家解答么么棋牌透视挂怎么安装这个问题咨询软件客服徽9752949的挂在哪里买很...
今日重磅消息“天天九州麻将到底... 网上科普关于“天天九州麻将有没有挂”话题很是火热,小编也是针对天天九州麻将作*弊开挂的方法以及开挂对...
【第一消息】“福建天天开心到底... 有 亲,根据资深记者爆料福建天天开心是可以开挂的,确实有挂(咨询软件无需...