5.5 Docker搭建redis主从+哨兵



1. redis 哨兵

redis主从复制结构中,主服务器会自动的将数据向从服务器复制;

哨兵可以监控到服务宕机,实时了解主服务器是否宕机,当主服务器宕机,会在从服务器中重新选举新的服务器用作主服务器;

客户端访问时,会由主服务器获取数据,但是客户端不确实到底哪个是主服务器,所以客户端先去访问哨兵,通过哨兵去访问主服务器;

我们首先通过redis搭建一主俩从的服务器集群;

2. 搭建主从服务器 – 一主两从

清理容器(可选)

docker rm -f $(docker ps -aq)

2.1 启动主服务器

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

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

2.2 启动两个从服务器

# 启动redis6380容器,--slaveof参数指定作为 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

2.3 查看启动服务器

分别进入3台服务器查看redis服务角色:

进入从服务器时,需要单独添加端口参数,因为默认的redis-cli客户端是连接主服务器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

在这里插入图片描述

在这里插入图片描述

2.4 查看主从复制

我们进入6379服务器添加数据,然后到6380访问数据,查看是否进行了主从复制:
在这里插入图片描述

3. 设置哨兵配置

创建哨兵的配置文件:

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

输入配置文件内容:
配置文件中的 sentinel monitor mymaster 192.168.64.150 6379 2中:

  • mymaster 是给主服务器取的名字
  • 末尾的 2 表示两个哨兵投票确认主服务器宕机,哨兵才会认为主服务器宕机

有时候可能哨兵会出现故障,当哨兵故障无法和主服务器通信时,可能会误报主服务器宕机,所以需要多个哨兵一起确定主服务器宕机,一般为投票选举,少数服务多数,例如5个哨兵配置3个,7个哨兵配置5个等;

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

在这里插入图片描述

4. 启动三个哨兵

4.1 启动命令

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

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

# 停止主服务器
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

在这里插入图片描述

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

package test;

import redis.clients.jedis.Jedis;
import redis.clients.jedis.JedisPoolConfig;
import redis.clients.jedis.JedisSentinelPool;

import java.util.HashSet;
import java.util.Set;

/**
 * 客户端连接主从集群
 * 1. 不直接连接主服务器,而是连接哨兵
 * 2. 通过哨兵连接主服务器
 * */
public class TestSentinel {
    public static void main(String[] args) {
        //哨兵服务器地址列表
        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("k1", "v1");
    }
}

运行代码并查看主从集群各个服务器中是否都有此数据:

在这里插入图片描述

在这里插入图片描述

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值