docker与docker-compose搭建redis1主2从3哨兵

2 篇文章 0 订阅
1 篇文章 0 订阅

docker安装redis

docker pull redis:latest

创建目录结构

用于挂载数据卷配置文件等

在这里插入图片描述

运行redis容器

主redis配置

下面这种方式挂载的配置文件不生效。

 docker run -d \
 --name master_redis_6379 \
  -p 6379:6379 \
   --restart unless-stopped \
   -v /mydata/master_redis/data:/data \
   -v /mydata/master_redis/conf/redis.conf:/etc/redis/redis.conf  \
   redis:latest 

即使我做了目录映射,docker容器中默认使用的redis.conf不是我映射的文件,需要指定配置文件才能生效,即在最后加上redis-server /etc/redis/redis.conf

 docker run -d \
 --name master_redis_6379 \
  -p 6379:6379 \
   --restart unless-stopped \
   -v /mydata/master_redis/data:/data \
   -v /mydata/master_redis/conf/redis.conf:/etc/redis/redis.conf  \
   redis:latest \
   redis-server /etc/redis/redis.conf
-v /mydata/redis/redis.conf:/etc/redis/redis.conf
将主机上的/mydata/redis/redis.conf路径映射到容器内的/etc/redis/redis.conf路径
-v /mydata/redis/data:/data
将主机上的/mydata/redis/data路径映射到容器内的/data路径。
--name master_redis-6379
给这个Docker容器起名为master_redis-6379。

master的redis.conf

bind 0.0.0.0
protected-mode no
port 6379
tcp-backlog 511
timeout 0
tcp-keepalive 300
supervised no
loglevel notice
#日志文件路径
#logfile "/mydata/master_redis/log/6379.log"
databases 16
always-show-logo yes
save ""
stop-writes-on-bgsave-error yes
rdbcompression yes
rdbchecksum yes
dbfilename dump6379.rdb
dir ./
masterauth "admin"
slave-serve-stale-data yes
slave-read-only yes
repl-diskless-sync no
repl-diskless-sync-delay 5
repl-disable-tcp-nodelay no
slave-priority 100
#slaveof ip1 6379
#slave-announce-ip ip1
#slave-announce-port 6379

#配置密码
requirepass "admin"

lazyfree-lazy-eviction no
lazyfree-lazy-expire no
lazyfree-lazy-server-del no
slave-lazy-flush no
#开启aof
appendonly yes
appendfilename "appendonly.aof"
appendfsync everysec
no-appendfsync-on-rewrite yes
auto-aof-rewrite-percentage 100
auto-aof-rewrite-min-size 64mb
aof-load-truncated yes
aof-use-rdb-preamble no
lua-time-limit 5000
slowlog-log-slower-than 10000
slowlog-max-len 128
latency-monitor-threshold 0
notify-keyspace-events ""
hash-max-ziplist-entries 512
hash-max-ziplist-value 64
list-max-ziplist-size -2
list-compress-depth 0
set-max-intset-entries 512
zset-max-ziplist-entries 128
zset-max-ziplist-value 64
hll-sparse-max-bytes 3000
activerehashing yes
client-output-buffer-limit normal 0 0 0
client-output-buffer-limit slave 256mb 64mb 60
client-output-buffer-limit pubsub 32mb 8mb 60
hz 10
aof-rewrite-incremental-fsync yes

这是一段Redis服务器的配置文件内容。下面是对这段配置的简单解析:

bind 0.0.0.0: 这意味着Redis将接受来自任何IP地址的连接。
protected-mode no: 这表示Redis将只在非安全模式下运行,也就是说,任何能够连接到Redis的客户端都可以执行命令。
port 6379: 这是Redis服务器监听的端口,通常Redis使用的是6379端口。
tcp-backlog 511: 这是TCP连接的排队长度。
timeout 0: 这表示Redis服务器等待客户端响应的时间,如果超过这个时间,服务器将关闭连接。设置为0表示没有超时限制。
tcp-keepalive 300: 这表示在客户端断开连接后,服务器将等待300秒再关闭TCP连接。
supervised no: 这表示Redis服务器的运行状态是否受操作系统监督。
loglevel notice: 这是Redis服务器日志的级别,这里设置为"notice",表示只记录重要的事件信息。
databases 16: 这表示Redis服务器默认创建16个数据库。
always-show-logo yes: 这个选项可能是在Redis启动时显示一些版权信息或版本信息。
save "": 这表示不进行任何数据持久化操作。
stop-writes-on-bgsave-error yes: 如果在后台保存(bgsave)数据时出现错误,是否停止写操作。
rdbcompression yes: 是否使用压缩算法来保存RDB文件。
rdbchecksum yes: 是否对RDB文件进行校验。
dbfilename dump.rdb: Redis保存数据的默认文件名是dump.rdb。
dir ./: 这表示Redis服务器将在当前目录下存储数据。
masterauth "admin": 这是Redis主服务器在进行复制操作时需要认证的密码。
slave-serve-stale-data yes: 从服务器是否提供旧数据,即使该数据可能已经过时。
slave-read-only yes: 从服务器是否只读。
repl-diskless-sync no: 是否使用磁盘来进行同步。
repl-diskless-sync-delay 5: 在使用磁盘同步数据时,是否延迟5秒再开始同步。
repl-disable-tcp-nodelay no: 是否禁用TCP_NODELAY选项。
slave-priority 100: 从服务器的优先级,默认值为100。
requirepass "admin": 客户端连接Redis时需要提供的密码。
lazyfree-lazy-eviction no: 是否立即释放被缓存的数据,而不是等待其自然释放。
lazyfree-lazy-expire no: 是否立即过期而不是等待其自然过期。
lazyfree-lazy-server-del no: 是否立即删除被缓存的数据而不是等待其自然删除。
slave-lazy-flush no: 从服务器是否立即刷新数据而不是等待其自然刷新。
appendonly yes: 是否开启AOF持久化功能。
appendfilename "appendonly.aof": AOF持久化文件的名称。
appendfsync everysec: AOF持久化文件同步的频率。
no-appendfsync-on-rewrite no: 在AOF重写期间是否同步数据到磁盘。
auto-aof-rewrite-percentage 100: 当AOF文件大小与最后一次重写后的差值超过这个百分比时,触发自动AOF重写。
auto-aof-rewrite-min-size 64mb: AOF重写的最小大小为64MB。
aof-load-truncated yes: 当AOF文件出现截断错误时,是否继续加载数据。
aof-use-rdb-preamble no: 是否在AOF文件的开头写入RDB格式的数据。
lua-time-limit 5000: Lua脚本执行的最大时间限制,单位为毫秒。
slowlog-log-slower-than 10000: 如果某个命令的执行时间超过这个值,将会被记录到慢日志中。
slowlog-max-len 128: 慢日志的最大长度,超过这个长度后将会覆盖最早的慢日志记录。
latency-monitor-threshold 0: 这个选项表示在哪个延迟阈值下触发警报,设置为0表示不触发警报。
notify-keyspace-events "": 这个选项表示当某个事件发生时触发哪些回调函数
hash-max-ziplist-entries 512: 对于Redis的哈希数据类型,如果一个哈希表中有超过512个不同的键值对,Redis会使用一种叫做"ziplist"的压缩列表来存储这个哈希表。这个选项可以增加或减少这个阈值。
hash-max-ziplist-value 64: 对于哈希表中的值,如果单个值的长度超过64字节,Redis会使用ziplist来存储这个哈希表。这个选项可以增加或减少这个阈值。
list-max-ziplist-size -2: 对于Redis的列表数据类型,如果一个列表的元素数量在-2000到2000之间,并且所有元素的长度都在64字节之内,Redis会使用ziplist来存储这个列表。
list-compress-depth 0: 这个选项决定了在列表中删除或插入元素时,Redis将尝试压缩列表的深度。设置为0表示不进行压缩。
set-max-intset-entries 512: 如果一个集合的所有元素都可以用32位整数表示,Redis会使用一种叫做"intset"的数据结构来存储这个集合。这个选项可以增加或减少这个阈值。
zset-max-ziplist-entries 128: 对于Redis的有序集合,如果一个成员在集合中出现的次数超过128次,Redis会使用ziplist来存储这个有序集合。
zset-max-ziplist-value 64: 对于有序集合中的成员的值,如果单个值的长度超过64字节,Redis会使用ziplist来存储这个有序集合。
hll-sparse-max-bytes 3000: HyperLogLog是一种用于估算元素数量的数据结构,这个选项定义了在使用稀疏表示法时,HyperLogLog的最大字节数。
activerehashing yes: 这个选项启用了"活跃的重新哈希"机制,它可以在后台进行哈希表的重新哈希,以优化哈希表的查询性能。
client-output-buffer-limit normal 0 0 0: 这个选项定义了正常客户端的输出缓冲限制。所有的限制都被设置为0,表示没有限制。
client-output-buffer-limit slave 256mb 64mb 60: 这个选项定义了从服务器的输出缓冲限制。从服务器最多可以使用256MB的输出缓冲区,如果超过64MB,从服务器将在60秒内关闭连接。
client-output-buffer-limit pubsub 32mb 8mb 60: 这个选项定义了发布/订阅客户端的输出缓冲限制。发布/订阅客户端最多可以使用32MB的输出缓冲区,如果超过8MB,发布/订阅客户端将在60秒内关闭连接。
hz 10: 这个选项定义了Redis服务器每秒执行的轮询(poll)操作的次数。轮询操作的次数越高,Redis的性能就越好,但是操作系统可能会因为频繁的上下文切换而受到影响。
aof-rewrite-incremental-fsync yes: 这个选项定义了在AOF持久化过程中是否进行增量式同步。设置为yes表示进行增量式同步。

主redis配置文件中,主要参数如下

bind 0.0.0.0: 这意味着Redis将接受来自任何IP地址的连接。

protected-mode no: 这表示Redis将只在非安全模式下运行,也就是说,任何能够连接到Redis的客户端都可以执行命令。

port 6379: 这是Redis服务器监听的端口,通常Redis使用的是6379端口。

requirepass "admin": 客户端连接Redis时需要提供的密码。

进入容器并进入redis命令行

 docker exec -it master_redis_6379 redis-cli

如果出现下面的问题,是需要登录

NOAUTH Authentication required.

解决方法

auth 密码

查看对应redis容器日志

docker logs master_redis_6379 

从redis配置

 docker run -d \
 --name slave_redis_6378 \
  -p 6378:6379 \
   --restart unless-stopped \
   -v /mydata/slave_redis/data:/data \
   -v /mydata/slave_redis/conf/redis.conf:/etc/redis/redis.conf  \
   redis:latest \
   redis-server /etc/redis/redis.conf

从redis主要配置文件

bind 0.0.0.0
protected-mode no
port 6379
tcp-backlog 511
timeout 0
tcp-keepalive 300
supervised no
loglevel notice
databases 16
always-show-logo yes
save ""
stop-writes-on-bgsave-error yes
rdbcompression yes
rdbchecksum yes
dbfilename dump.rdb
dir ./
#replicaof 47.120.0.38 6379
masterauth "admin"
slave-serve-stale-data yes
slave-read-only yes
repl-diskless-sync no
repl-diskless-sync-delay 5
repl-disable-tcp-nodelay no
slave-priority 100
requirepass "admin"
lazyfree-lazy-eviction no
lazyfree-lazy-expire no
lazyfree-lazy-server-del no
slave-lazy-flush no
appendonly yes
appendfilename "appendonly.aof"
appendfsync everysec
no-appendfsync-on-rewrite yes
auto-aof-rewrite-percentage 100
auto-aof-rewrite-min-size 64mb
aof-load-truncated yes
aof-use-rdb-preamble no
lua-time-limit 5000
slowlog-log-slower-than 10000
slowlog-max-len 128
latency-monitor-threshold 0
notify-keyspace-events ""
hash-max-ziplist-entries 512
hash-max-ziplist-value 64
list-max-ziplist-size -2
list-compress-depth 0
set-max-intset-entries 512
zset-max-ziplist-entries 128
zset-max-ziplist-value 64
hll-sparse-max-bytes 3000
activerehashing yes
client-output-buffer-limit normal 0 0 0
client-output-buffer-limit slave 256mb 64mb 60
client-output-buffer-limit pubsub 32mb 8mb 60
hz 10
aof-rewrite-incremental-fsync yes

#slave-announce-ip ip2
#slave-announce-port 6379
slaveof 47.120.0.38 6379

主要参数

bind 0.0.0.0
protected-mode no
port 6379
slaveof 47.120.0.38 6379  //设置主redis的地址以及端口号
masterauth "admin"     //用于登录到主redis的密码

查看主从节点的复制状态

xxxx.xxx:6379> info replication

在这里插入图片描述
在这里插入图片描述

docker 搭建redis主从

version: '3.1'
services:
  master:
    image: redis:latest
    container_name: master_redis_6379
    restart: always
    ports:
      - 6379:6379
    command: redis-server /etc/redis/redis.conf
    volumes:
      - ./master_redis/data:/data
      - ./master_redis/conf/redis.conf:/etc/redis/redis.conf

  slave1:
    image: redis:latest
    container_name: slave_redis_6377
    restart: always
    ports:
      - 6377:6377
    command: redis-server /etc/redis/redis.conf
    volumes:
      - ./slave_redis/data_6377:/data
      - ./slave_redis/conf_6377/redis.conf:/etc/redis/redis.conf

  slave2:
    image: redis:latest
    container_name: slave_redis_6378
    ports:
      - 6378:6378
    command: redis-server /etc/redis/redis.conf
    volumes:
      - ./slave_redis/data_6378:/data
      - ./slave_redis/conf_6378/redis.conf:/etc/redis/redis.conf

搭建哨兵集群

确保自己安装了docker-compose
安装教程

https://editor.csdn.net/md/?articleId=131579797

在这里插入图片描述

新建如图所示目录
在这里插入图片描述

sentinel.conf内容

#  bind 0.0.0.0
# 禁止保护模式
protected-mode no

port 26379

就是下面这条命令,浪费了我3个小时,
# daemonize yes

 dir /tmp

#  tcp-backlog 511

  masterauth "admin"
#  requirepass admin

# 配置监听的主服务器,这里sentinel monitor代表监控,mymaster代表服务器的名称,可以自定义,192.168.118.202代表监控的主服务器,6379代表端口,2代表只有两个或两个以上的哨兵认为主服务器不可用的时候,才会进行failover操作。
sentinel monitor mymaster 47.120.0.38 6379 2
# sentinel author-pass定义服务的密码,mymaster是服务名称,123456是Redis服务器密码
# sentinel auth-pass <master-name> <password>
sentinel auth-pass mymaster admin

# 指定多少毫秒之后 主节点没有应答哨兵sentinel 此时 哨兵主观上认为主节点下线 默认30秒
sentinel down-after-milliseconds mymaster 5000
# 指定了在发生failover主备切换时最多可以有多少个slave同时对新的master进行同步,这个数字越小,完成failover所需的时间就越长
 sentinel parallel-syncs mymaster 1
# 故障转移的超时时间
sentinel failover-timeout mymaster 5000

编写docker-compose.yml文件

version: "3.0"
services:
  #sentinel1
  sentinel_redis_1:
    image: redis:latest
    restart: always
    container_name: sentinel_redis_1
    ports:
      - 26379:26379
    environment:
      - TZ=Asia/Shanghai
    #执行的命令
    command: redis-sentinel  /etc/redis/sentinel.conf
    volumes:
      - ./conf/sentinel.conf:/etc/redis/sentinel.conf
      - ./data/sentinel_redis_1:/data
  #sentinel2
  sentinel_redis_2:
    image: redis:latest
    restart: always
    container_name: sentinel_redis_2
    ports:
      - 26380:26379
    environment:
      - TZ=Asia/Shanghai
    #执行的命令
    command: redis-sentinel  /etc/redis/sentinel.conf
    volumes:
      - ./conf/sentinel.conf:/etc/redis/sentinel.conf
      - ./data/sentinel_redis_2:/data
  #sentinel3
  sentinel_redis_3:
    image: redis:latest
    restart: always
    container_name: sentinel_redis_3
    ports:
      - 26381:26379
    environment:
      - TZ=Asia/Shanghai
    command: redis-sentinel  /etc/redis/sentinel.conf
    volumes:
      - ./conf/sentinel.conf:/etc/redis/sentinel.conf
      - ./data/sentinel_redis_3:/data
networks:
  default:
    external: true
    name: redis_default

在存在该yml的文件下执行

docker-compose up -d

启动成功后可以产看容器日志

docker logs 容器名

遇到的问题

1.docker-compose编排的容器一直在显示重启
打印日志也为空

原因

当daemonize 设置了yes,表示redis在后台运行,当执行docker-compose执行启动redis进程时,docker发现自己无事可做,容器自动结束,所以导致redis启动失败。

解决方法

注释掉

遇到问题

2.哨兵节点监听不到master,即使master下线后,哨兵也不起作用

原因

redis在设置端口是一定要修改容器内的端口,不要都是6379,防止哨兵监听不到。

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要使用docker-compose搭建Redis集群,你可以按照以下步骤进行操作: 1. 创建一个docker-compose.yml文件,并在其中定义Redis集群的服务。你可以使用以下示例作为参考: ``` version: '3' services: redis-6379: image: redis ports: - "6379:6379" volumes: - ./redis-6379:/data command: redis-server /data/redis.conf redis-6380: image: redis ports: - "6380:6379" volumes: - ./redis-6380:/data command: redis-server /data/redis.conf redis-6381: image: redis ports: - "6381:6379" volumes: - ./redis-6381:/data command: redis-server /data/redis.conf redis-6382: image: redis ports: - "6382:6379" volumes: - ./redis-6382:/data command: redis-server /data/redis.conf redis-6383: image: redis ports: - "6383:6379" volumes: - ./redis-6383:/data command: redis-server /data/redis.conf redis-6384: image: redis ports: - "6384:6379" volumes: - ./redis-6384:/data command: redis-server /data/redis.conf ``` 2. 在每个Redis服务的目录中创建一个redis.conf文件,用于配置Redis集群的参数。你可以使用以下示例作为参考: ``` port 6379 cluster-enabled yes cluster-config-file nodes.conf cluster-node-timeout 5000 appendonly yes ``` 3. 运行docker-compose命令来启动Redis集群: ``` docker-compose up -d ``` 这将启动Redis集群的所有服务,并将它们连接在一起。 请注意,以上步骤中的示例仅适用于在本地搭建Redis集群。如果你需要在生产环境中搭建Redis集群,你可能需要进行更多的配置和安全性措施。 #### 引用[.reference_title] - *1* *2* *3* [docker(八)—docker-compose搭建redis集群](https://blog.csdn.net/xiaoqiang65/article/details/121011071)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down1,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值