docker配置Redis哨兵Sentinel模式

 

            docker配置Redis哨兵Sentinel模式_第1张图片

Redis服务配置:

# 使得Redis服务器可以跨网络访问
bind 0.0.0.0
# 设置密码
requirepass "123456"
# 指定主服务器,注意:有关slaveof的配置只是配置从服务器,主服务器不需要配置
slaveof 127.0.0.1 6379
# 主服务器密码,注意:有关slaveof的配置只是配置从服务器,主服务器不需要配置
masterauth 123456

 

哨兵配置:

只需要待监控的主服务,并给它取一个唯一的名称,从服务会被自动检查到,不需要手动指定。每个哨兵配置一样。

以下几种情况发生时,哨兵将更新配置文件:

1.新的从服务被侦测到

2.当异常发生,有从服务被提升为主服务时

3.新的哨兵被侦测到时

# 禁止保护模式
protected-mode no
# 配置监听的主服务器,这里sentinel monitor代表监控,mymaster代表服务器的名称,可以自定义,192.168.11.128代表监控的主服务器,6379代表端口,2代表只有两个或两个以上的哨兵认为主服务器不可用的时候,才会进行failover操作。
sentinel monitor redismaster 127.0.0.1 6379 2
# sentinel author-pass定义服务的密码,redismaster是服务名称,123456是Redis服务器密码
# sentinel auth-pass  
sentinel auth-pass mymaster 123456

其他配置项:

配置项 参数类型 作用
port 整数 启动哨兵进程端口
dir 文件夹目录 哨兵进程服务临时文件夹,默认为/tmp,要保证有可写入的权限
sentinel down-after-milliseconds <服务名称><毫秒数(整数)> 指定哨兵在监控Redis服务时,当Redis服务在一个默认毫秒数内都无法回答时,单个哨兵认为的主观下线时间,默认为30000(30秒)
sentinel parallel-syncs <服务名称><服务器数(整数)> 指定可以有多少个Redis服务同步新的主机,一般而言,这个数字越小同步时间越长,而越大,则对网络资源要求越高
sentinel failover-timeout <服务名称><毫秒数(整数)> 指定故障切换允许的毫秒数,超过这个时间,就认为故障切换失败,默认为3分钟
sentinel notification-script <服务名称><脚本路径> 指定sentinel检测到该监控的redis实例指向的实例异常时,调用的报警脚本。该配置项可选,比较常用

sentinel down-after-milliseconds配置项只是一个哨兵在超过规定时间依旧没有得到响应后,会自己认为主机不可用。对于其他哨兵而言,并不是这样认为。哨兵会记录这个消息,当拥有认为主观下线的哨兵达到sentinel monitor所配置的数量时,就会发起一次投票,进行failover,此时哨兵会重写Redis的哨兵配置文件,以适应新场景的需要。

启动:

docker run -p 16379:6379 -v /home/data/redis-cluster/redis-alpha:/data  -d --name=alpha redis:latest --appendonly yes
docker exec -i -t  alpha /bin/bash

# 启动Redis服务器进程 ./redis-server ../redis.conf

# 启动哨兵进程 ./redis-sentinel ../sentinel.conf

你可能感兴趣的:(docker配置Redis哨兵Sentinel模式)