redission连接sentinel 密码 redis sentinel 密码_docker

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 <master-name> <password>
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