docker搭建redis主从复制

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

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

bash 复制代码
NOAUTH Authentication required.

解决方法

bash 复制代码
auth 密码

查看对应redis容器日志

docker logs master_redis_6379 

从redis配置

bash 复制代码
 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主要配置文件

bash 复制代码
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

主要参数

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

查看主从节点的复制状态

bash 复制代码
xxxx.xxx:6379> info replication


相关推荐
敲代码不忘补水1 小时前
Docker 启动 PostgreSQL 主从架构:实现数据同步的高效部署指南
docker·postgresql·架构·数据库架构
技术卷3 小时前
Redis数据库与GO(一):安装,string,hash
数据库·redis·golang
长天一色4 小时前
【Docker从入门到进阶】06.常见问题与解决方案 & 07.总结与资源
运维·docker·容器
妍妍的宝贝7 小时前
k8s 中的金丝雀发布(灰度发布)
云原生·容器·kubernetes
iangyu9 小时前
docker常用命令
运维·docker·容器
CoderJia程序员甲10 小时前
重学SpringBoot3-集成Redis(四)之Redisson
java·spring boot·redis·缓存
深山夕照深秋雨mo10 小时前
在Java中操作Redis
java·开发语言·redis
阳光阿盖尔10 小时前
redis——哨兵机制
数据库·redis·缓存·主从复制·哨兵
小小娥子10 小时前
【Redis】Hash类型的常用命令
数据库·spring boot·redis
盒马盒马10 小时前
Redis:cpp.redis++通用接口
数据库·c++·redis