详解使用Docker进行Redis主从复制实践

论坛 期权论坛 脚本     
niminba   2021-5-23 05:01   2456   0

一、背景

最近在做零信任安全网关,需要使用Redis作为认证缓存服务器,因为网关服务器分布在多个集群,每次都跨机房认证不太实现;所以需要使用Redis主从同步,将过程记录下来,希望可以给需要的同学一点参考。

二、操作步骤

  • 安装Docker
  • 主服务配置
  • 从服务配置
  • 验证同步效果

三、安装Docker

本篇文章主要是问了记录主从配置的过程,因此我采用最简单的docker方式来搭建Redis服务,安装docker的命令如下所示

curl -sSL https://get.daocloud.io/docker | sh

命令执行完成之后,可以看到如下图所示界面

在上图中可以看到docker的一些相关信息,我们要确认docker安装是否成功还可以使用docker info命令进行查看,执行命令如下所示

docker info 

命令执行之后,返回信息如下图所示

在上图中可以看到docker的版本信息为20.10.3,这是目前的最新版本,已经确认安装成功无误。

四、主服务配置

接下来我需要使用docker安装Redis服务,我在实践过程中发现直接使用Redis镜像有些异常,于是使用centos镜像,再在容器里安装Redis,运行容器的命令如下所示

docker run -d -it -p 16379:6379  --name  redis_master  centos:7

命令执行完毕之后再进入该容器,进入容器的命令如下所示

docker exec -it redis_master  bash

命令执行完毕后,返回的信息如下图所示

在上图中可以看到已经成功的进入到了容器里面,接下来我需要在容器里安装Redis,安装Redis的命令如下所示

yum install -y epel-release  && yum install -y redis

命令执行完毕之后,返回的信息如下图所示

从上图中可以看到,Redis已经安装完成,接下来需要新建一个Redis的主库配置文件,执行命令如下所示

vi  ~/master.conf

配置文件如下所示,将下列配置文件复制并粘贴到vi编辑窗口当中。

#bind 0.0.0.0
protected-mode yes
port 6379
tcp-backlog 511
unixsocket /tmp/redis_auth.sock
unixsocketperm 777
timeout 0
tcp-keepalive 300
daemonize yes
supervised auto
pidfile /var/run/redis_auth.pid
loglevel debug
logfile /tmp/redis_auth.log
databases 16
save ""
stop-writes-on-bgsave-error yes
rdbcompression yes
rdbchecksum yes
dbfilename dump.rdb
dir /var/lib/redis
requirepass 123123123
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
appendonly yes
appendfilename "funfe.aof"
appendfsync everysec
no-appendfsync-on-rewrite no
auto-aof-rewrite-percentage 100
auto-aof-rewrite-min-size 512mb
aof-load-truncated yes
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
hz 10
aof-rewrite-incremental-fsync yes

在vi编辑窗口粘贴后,如下图所示

粘贴完成并检查无误之后,使用:wq!命令进行保存,接着就可以启动Redis程序,启动的命令如下所示

redis-server `/redis.conf

在上方的启动命令中需要指定配置文件路径,如下图所示

在上图中可以看到Redis服务已经启动完成。

五、从服务配置

接下来我需要再次启动一个Redis从库服务器,运行容器的命令如下所示



分享到 :
0 人收藏
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

积分:1060120
帖子:212021
精华:0
期权论坛 期权论坛