在workspace中创建文件和目录
- 在workspace中创建
文件夹redis-sentinel
- 在
中创建redis-sentinel
文件夹sentinel
- 在sentinel创建
Dockerfilesentinel.conf`` 、
sentinel-entrypoint.sh```三个文件、
- 回到redis-sentinel目录创建
文件docker-compose.yml
整个文件结构如图:
![](https://img.laitimes.com/img/_0nNw4CM6IyYiwiM6ICdiwiI0gTMx81dsQWZ4lmZf1GLlpXazVmcvwFciV2dsQXYtJ3bm9CX9s2RkBnVHFmb1clWvB3MaVnRtp1XlBXe0xCMy81dvRWYoNHLwEzX5xCMx8FesU2cfdGLwMzX0xiRGZkRGZ0Xy9GbvNGLpZTY1EmMZVDUSFTU4VFRR9Fd4VGdsYTMfVmepNHLrJXYtJXZ0F2dvwVZnFWbp1zczV2YvJHctM3cv1Ce-cmbw5CN3MDM5czY1YmYkRTZ3QjNzYzX3UTM1ATM0AzLcFTMyIDMy8CXn9Gbi9CXzV2Zh1WavwVbvNmLvR3YxUjLyM3Lc9CX6MHc0RHaiojIsJye.png)
sentinel.conf
# sentinel monitor {masterName} {masterIp} {masterPort} {quorum} sentinel monitor masterName为哨兵masterId 指定了主节点IP和端口
sentinel monitor mymaster redis-master 6379 2
# 当哨兵发出ping命令 超过5秒则判断为主观下线
sentinel down-after-milliseconds mymaster 5000
# 每次故障转以后,从节点向新的主节点发起复制操作的节点个数,可以减轻Master的压力
sentinel parallel-syncs mymaster 1
# 故障转移超时时间
sentinel failover-timeout mymaster 5000
Dockerfile
# 建立Dockerfile指定基础镜像,同时拷贝配置文件到镜像内部
FROM redis
EXPOSE 26379
ADD sentinel.conf /etc/redis/sentinel.conf
RUN chown redis:redis /etc/redis/sentinel.conf
COPY sentinel-entrypoint.sh /usr/local/bin/
RUN chmod +x /usr/local/bin/sentinel-entrypoint.sh
ENTRYPOINT ["sentinel-entrypoint.sh"]
sentinel-entrypoint.sh
#!/bin/sh
sed -i "s/$SENTINEL_QUORUM/$SENTINEL_QUORUM/g" /etc/redis/sentinel.conf
sed -i "s/$SENTINEL_DOWN_AFTER/$SENTINEL_DOWN_AFTER/g" /etc/redis/sentinel.conf
sed -i "s/$SENTINEL_FAILOVER/$SENTINEL_FAILOVER/g" /etc/redis/sentinel.conf
exec docker-entrypoint.sh redis-server /etc/redis/sentinel.conf --sentinel
docker-compose.yml
version: '3.5'
networks:
app-tier:
driver: bridge
services:
redis:
image: 'bitnami/redis:latest'
restart: always
environment:
- REDIS_REPLICATION_MODE=master
- REDIS_PASSWORD=""
networks:
- app-tier
ports:
- '6379:6379'
redis-slave:
image: 'bitnami/redis:latest'
restart: always
environment:
- REDIS_REPLICATION_MODE=slave
- REDIS_MASTER_HOST=redis
- REDIS_MASTER_PASSWORD=""
- REDIS_PASSWORD=""
ports:
- '6380:6379'
depends_on:
- redis
networks:
- app-tier
redis-slave2:
image: 'bitnami/redis:latest'
restart: always
environment:
- REDIS_REPLICATION_MODE=slave
- REDIS_MASTER_HOST=redis
- REDIS_MASTER_PASSWORD=""
- REDIS_PASSWORD=""
ports:
- '6381:6379'
depends_on:
- redis
networks:
- app-tier
redis-sentinel:
image: 'bitnami/redis-sentinel:latest'
restart: always
environment:
- REDIS_MASTER_HOST=127.0.0.1
- REDIS_MASTER_PASSWORD=""
depends_on:
- redis
- redis-slave
- redis-slave2
ports:
- '26379-26381:26379'
networks:
- app-tier
创建容器
创建好文件结构后回到
redis-sentinel
目录,执行一下语句即可:
docker-compose up --scale redis-sentinel=1