mongodb分片副本集高可用部署

本文以三节点为例,详细介绍了MongoDB的高可用架构部署,包括关闭iptables,禁止THP,搭建config server副本集,shard副本集,以及启动mongos集群和分片设置,确保在任意节点故障时,集群仍保持可用。
摘要由CSDN通过智能技术生成

以三节点为例,详细介绍mongodb高可用架构部署

1、机器列表(ip是虚构的,可根据实际情况修改)

172.16.10.1

172.16.10.2

172.16.10.3

操作系统为centos6.5

ip 172.16.10.1 172.16.10.2 172.16.10.3 端口
组件 mongos mongos mongos 20000
config server config server config server 21000
shard1 shard1 shard1 27001
shard2 shard2 shard2 27002
  shard3 shard3 shard3 27003

从上面的表格可以看出来,在机器规划时主要考虑一下几个方面

1、每个分片的三个副本分别位于三个节点服务器上,这样可以保证任意一台机器出现故障集群仍然可用

2、标绿色的为每个分片的primary节点,将是哪个分片的主节点分散到三个不同服务器,可以将数据写的压力均分

3、本教程将mongos和mongod部署在一起,实际应用时,mongos可以单独部署

2、服务器准备

1、关闭iptables

 service  iptables stop;
 chkconfig  iptables off;

2、禁止Transparent Huge Pages

mongodb官网明确指出,THP对于mongodb的性能有很大影响,具体可参考https://docs.mongodb.com/manual/tutorial/transparent-huge-pages/的说明

(1)查看THP状态

 cat /sys/kernel/mm/transparent_hugepage/defrag;
[always] madvise never
 cat /sys/kernel/mm/transparent_hugepage/enabled;
[always] madvise never

上述状态说明THP是开启的

(2)禁用THP

echo never > /sys/kernel/mm/transparent_hugepage/enabled

echo never > /sys/kernel/mm/transparent_hugepage/defrag

(3)开启自动禁用

编辑/etc/rc.d/rc.local ,在最后追加如下内容

if test -f /sys/kernel/mm/transparent_hugepage/enabled; then
echo never > /sys/kernel/mm/transparent_hugepage/enabled
fi
if test -f /sys/kernel/mm/transparent_hugepage/defrag; then
echo never > /sys/kernel/mm/transparent_hugepage/defrag
fi

3、修改zone_recla

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值