Docker搭建redis主从+哨兵

Posted Wanght6

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Docker搭建redis主从+哨兵相关的知识,希望对你有一定的参考价值。




redis 哨兵

redis主从复制结构中,当主服务器宕机,哨兵可以监控到服务宕机,在从服务器中选举产生一个新的主服务器。




搭建主从服务器 —— 一主两从

清理容器(可选)

docker rm -f $(docker ps -aq)




启动主服务器

# --net=host 容器直接使用宿主机的端口,不需要做端口映射
docker run -d --name redis6379 --net=host --restart=always redis 

# 进入容器,运行redis客户端
docker exec -it redis6379 redis-cli

# 查看集群信息,默认是主服务器
> info replication




启动两个从服务器

# 启动redis6380容器,作为 redis6379 的从服务器启动
# --port 和 --slaveof 是 redis-server 命令的参数
docker run -d --name redis6380 --net=host --restart=always redis \\
redis-server --port 6380 --slaveof 192.168.64.150 6379

# 启动redis6381容器,作为 redis6379 的从服务器启动
docker run -d --name redis6381 --net=host --restart=always redis \\
redis-server --port 6381 --slaveof 192.168.64.150 6379

# 查看三个 redis 服务的角色
docker exec -it redis6379 redis-cli
> info replication

docker exec -it redis6380 redis-cli -p 6380
> info replication

docker exec -it redis6381 redis-cli -p 6381
> info replication




启动哨兵

哨兵的配置文件

mkdir /opt/sentinel/
cd /opt/sentinel/

# 配置文件中的 "sentinel monitor mymaster 192.168.64.150 6379 2"
# 末尾的 2 表示两台从服务器投票确认主服务器宕机,哨兵才会认为主服务器宕机
cat <<EOF >5000.conf
port 5000
sentinel monitor mymaster 192.168.64.150 6379 2
sentinel down-after-milliseconds mymaster 5000
sentinel failover-timeout mymaster 60000
sentinel parallel-syncs mymaster 1
EOF

cat <<EOF >5001.conf
port 5001
sentinel monitor mymaster 192.168.64.150 6379 2
sentinel down-after-milliseconds mymaster 5000
sentinel failover-timeout mymaster 60000
sentinel parallel-syncs mymaster 1
EOF

cat <<EOF >5002.conf
port 5002
sentinel monitor mymaster 192.168.64.150 6379 2
sentinel down-after-milliseconds mymaster 5000
sentinel failover-timeout mymaster 60000
sentinel parallel-syncs mymaster 1
EOF




启动三个哨兵

docker run -d --name sentinel5000 \\
-v /opt/sentinel/5000.conf:/sentinel.conf \\
--net=host \\
redis redis-sentinel /sentinel.conf

docker run -d --name sentinel5001 \\
-v /opt/sentinel/5001.conf:/sentinel.conf \\
--net=host \\
redis redis-sentinel /sentinel.conf

docker run -d --name sentinel5002 \\
-v /opt/sentinel/5002.conf:/sentinel.conf \\
--net=host \\
redis redis-sentinel /sentinel.conf

# 进入一个哨兵容器,查看它监控的主从服务器和其他哨兵
docker exec -it sentinel5000 redis-cli -p 5000
> sentinel master mymaster
> sentinel slaves mymaster
> sentinel sentinels mymaster




停止主服务器,测试主服务器重新选举

# 停止主服务器
docker stop redis6379
# 在哨兵日志中查看服务器切换日志: +switch-master mymaster 192.168.64.150 6379 192.168.64.150 6381
docker logs sentinel5000

# 查看 6380 和 6381 服务器的角色变化
docker exec -it redis6380 redis-cli -p 6380
> info replication

docker exec -it redis6381 redis-cli -p 6381
> info replication




重新启动6379,不会把6379切换成主服务器,而是作为从服务器

docker start redis6379

docker exec -it redis6379 redis-cli
> info replication




客户端api连接哨兵存取数据

        Set<String> sets = new HashSet<>();
        sets.add("192.168.64.151:5000");
        sets.add("192.168.64.151:5001");
        sets.add("192.168.64.151:5002");

        JedisPoolConfig poolConfig = new JedisPoolConfig();

        JedisSentinelPool pool = new JedisSentinelPool("mymaster",sets,poolConfig);
        Jedis jedis = pool.getResource();
        jedis.set("a", "aaaaaaa");
        System.out.println(jedis.get("a"));
        jedis.close();

以上是关于Docker搭建redis主从+哨兵的主要内容,如果未能解决你的问题,请参考以下文章

Docker教程-6-在Redis主从复制基础上搭建哨兵模式

Docker教程-6-在Redis主从复制基础上搭建哨兵模式

docker搭建Redis6.2哨兵集群

docker搭建Redis6.2哨兵集群

docker搭建Redis6.2哨兵集群

docker搭建Redis6.2哨兵集群