redis高可用之哨兵模式

redis5.0.6下载地址
1、创建目录

# 创建目录

mkdir -p /var/redis-sentinel/redis-master
mkdir -p /var/redis-sentinel/redis-slaver1
mkdir -p /var/redis-sentinel/redis-slaver2
mkdir -p /var/redis-sentinel/sentinel1
mkdir -p /var/redis-sentinel/sentinel2
mkdir -p /var/redis-sentinel/sentinel3

下载源码,解压并进入到/var/redis-5.0.5/src/

2、安装到master

make   install PREFIX=/var/redis-sentinel/redis-master

拷贝配置文件redis.conf

cp /var/redis-5.0.5/redis.conf /var/redis-ms/redis-master/bin 

修改配置文件

 # 将`daemonize`由`no`改为`yes`  
 daemonize yes    
 # 默认绑定的是回环地址,默认不能被其他机器访问  
 # bind 127.0.0.1    
 # 是否开启保护模式,由yes该为no  
 protected-mode no  

3、分别复制到slave1和slave2

cp -r /var/redis-sentinel/redis-master/* /var/redis-sentinel/redis-slaver1
#修改配置文件 
vim /var/redis-sentinel/redis-slaver1/redis.conf 

port 6380 
replicaof 127.0.0.1 6379

cp -r /var/redis-sentinel/redis-master/* /var/redis-sentinel/redis-slaver2
#修改配置文件 
vim /var/redis-sentinel/redis-slaver2/redis.conf 

port 6381 
replicaof 127.0.0.1 6379

4、复制到sentinel1

#拷贝sentinel.conf 配置文件并修改 
cp /var/redis-5.0.5/sentinel.conf /var/redis-sentinel/sentinel1


# 哨兵sentinel实例运行的端口 默认26379 
port 26379 

# 将`daemonize`由`no`改为`yes`
daemonize yes   

# 哨兵sentinel监控的redis主节点的 ip port 
# master-name  可以自己命名的主节点名字 只能由字母A-z、数字0-9 、这三个字符".-_"组成。 
# quorum 当这些quorum个数sentinel哨兵认为master主节点失联 那么这时 客观上认为主节点失联了 
# sentinel monitor <master-name> <ip> <redis-port> <quorum> 
sentinel monitor mymaster 127.0.0.1 6379 2

# 当在Redis实例中开启了requirepass foobared 授权密码 这样所有连接Redis实例的客户端都要提 供密码 
# 设置哨兵sentinel 连接主从的密码 注意必须为主从设置一样的验证密码 
# sentinel auth-pass <master-name> <password> 
sentinel auth-pass mymaster MySUPER--secret-0123passw0rd
 
# 指定多少毫秒之后 主节点没有应答哨兵sentinel 此时 哨兵主观上认为主节点下线 默认30秒,改成3秒 
# sentinel down-after-milliseconds <master-name> <milliseconds> 
sentinel down-after-milliseconds mymaster 3000
 
# 这个配置项指定了在发生failover主备切换时最多可以有多少个slave同时对新的master进行 同步, 这个数字越小,完成failover所需的时间就越长, 但是如果这个数字越大,就意味着越 多的slave因为replication而不可用。 可以通过将这个值设为 1 来保证每次只有一个slave 处于不能处理命令请求的状态。 
# sentinel parallel-syncs <master-name> <numslaves> 
sentinel parallel-syncs mymaster 1
 
# 故障转移的超时时间 failover-timeout 可以用在以下这些方面: 
#1. 同一个sentinel对同一个master两次failover之间的间隔时间。 
#2. 当一个slave从一个错误的master那里同步数据开始计算时间。直到slave被纠正为向正确的master 那里同步数据时。 
#3.当想要取消一个正在进行的failover所需要的时间。   
#4.当进行failover时,配置所有slaves指向新的master所需的最大时间。不过,即使过了这个超时, slaves依然会被正确配置为指向master,但是就不按parallel-syncs所配置的规则来了
# 默认三分钟 # sentinel failover-timeout <master-name> <milliseconds> 
sentinel failover-timeout mymaster 180000

5、将sentinel1复制到sentinel2、sentinel3,并修改各自端口

cp -r /var/redis-sentinel/sentinel1/* /var/redis-sentinel/sentinel2

#修改sentinel.conf 
vim /var/redis-sentinel/sentinel2/sentinel.conf 
port 26380

cp -r /var/redis-sentinel/sentinel1/* /var/redis-sentinel/sentinel3

#修改sentinel.conf 
vim /var/redis-sentinel/sentinel3/sentinel.conf 
port 26381

6、启动脚本

/var/redis-sentinel/redis-master/bin/redis-server redis.conf
/var/redis-sentinel/redis-slaver1/bin/redis-server redis.conf
/var/redis-sentinel/redis-slaver2/bin/redis-server redis.conf
/var/redis-sentinel/sentinel1/bin/redis-server redis.conf
/var/redis-sentinel/sentinel2/bin/redis-server redis.conf
/var/redis-sentinel/sentine3/bin/redis-server redis.conf

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值