详解使用Docker进行Redis主从复制实践
作者:汤青松 发布时间:2022-09-28 16:58:22
目录
一、背景
二、操作步骤
三、安装Docker
四、主服务配置
五、从服务配置
六、结果验证
6.1 初步验证
6.2 同步检查
一、背景
最近在做零信任安全网关,需要使用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从库服务器,运行容器的命令如下所示
docker run -d -it -p 26379:6379 --name redis_slave centos:7
在上方的命令中,因为在同一台主机,为了不和主库端口产生冲突,我将主机端口26379,启动完成之后就可以进入从库容器,运行的命令如下所示
docker exec -it redis_slave bash
命令执行完毕后,同样需要新建一个Redis的配置文件,运行的命令如下所示
vi ~/redis.conf
在配置文件中,需要加入从库的配置代码,配置样例如下所示
bind 127.0.0.1
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_6379.pid
loglevel notice
logfile /tmp/redis.log
databases 16
save ""
stop-writes-on-bgsave-error yes
rdbcompression yes
rdbchecksum yes
dbfilename dump.rdb
dir /var/lib/redis
slaveof 172.23.193.148 16379
masterauth 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
将配置样例复制进来之后,窗口如下所示
粘贴完成并检查无误之后,使用:wq!命令进行保存,接着就可以启动Redis程序,启动的命令如下所示
接着安装Redis服务,安装命令如下所示
yum install -y epel-release && yum install -y redis
命令执行完毕之后,返回的信息如下图所示
在上图中可以看到从库的Redis也安装完成了,接下来使用redis-server命令启动从库服务器,命令如下图所示
redis-server redis.conf
命令执行完毕之后,返回的信息如下图所示
在上图中可以看到Redis已经启动完成,接下来就可以进行验证效果了
六、结果验证
验证方法主要是在主库中设置数据,观察从库是否也会同步更新;
6.1 初步验证
不过这种操作有点麻烦,我们最好是先检查一下从库的启动日志,查看启动日志的命令如下所示
cat /tmp/redis.log
命令执行完毕之后,会返回Redis的日志信息,如下图所示
在上图中的日志信息可以看到从库已经成功将主库信息复制到本地来了。
6.2 同步检查
虽然日志中提示成功了,不过是否成功主从同步还是要以实际效果为准,这里我回到主服务器的终端窗口,然后进入redis的命令控制台,进入控制台的命令如下所示
redis-cli -a 123123123
命令执行之后,就可以进行redis命令操作了,这里我设置一个test为123123的键值对,设置命令如下所示
set test 123123
命令执行完毕之后,返回的信息如下图所示
在上图中可以看到Redis已经提示设置键值对成功了,接下来我继续回到从库的终端窗口,然后进入Redis的控制台,执行命令如下所示
redis-cli -a 123123123
命令执行完毕之后,就可以通过keys命令查看当前从库的键值对,命令如下所示
keys *
命令执行完毕之后,返回的信息如下图所示
在上图中可以看到test这个数据已经成功复制过来了。
来源:https://juejin.cn/post/6949904940311691271


猜你喜欢
- 10月10日消息,据南方都市报报道,新闻出版总署有关负责人昨日表示,10月份新闻出版总署将集中力量联合组织一次对网络游戏审批和运营服务的全面
- 做站也有一段时间了,总的来说,从开始建站到现在,一路的辛酸与快乐只有自己心里清楚,但是,走过来的站长之路也只是重复其它的站长的脚步而已,最近
- 1. 与备份有关的VMWare基础知识1.1 VMware 虚机磁盘在 ESXi 宿主机上的文件简单来说,虚机的每个虚拟磁盘由ESXi 宿主
- 今天看我的BLOG(zishu.cn)还有以前另一个站的统计,发现和SEO相关的一点东西,写出来和大家分享一下!我的观点是“放弃无效的收录,
- 个人认为一个站点要运营成功的有这么几个要素(从客户访问网站的角度)。我们可以模拟客户游历网站的过程,一个客户在网上游历,偶然中通过搜索引擎或
- 熟悉Windows Server 2003的朋友,相信对RMS(权限管理服务)都不会陌生,它能够有效的保护我们的数字资产在相应授权范围之外不
- 网店刚开张的时候,有多事情需要网店新手去做,可以说刚开始经营网店是很辛苦的,不过现在的辛苦是为了以后能很好的,轻松的管理好我们的店铺,下面说
- 在Windows下资源管理器查看内存使用的情况,如果使用率达到80%以上,再运行大程序就能感觉到系统不流畅了,因为在内存紧缺的情况下使用交换
- 侧边栏的标签云(Tag Cloud)一直是 WordPress 2.3+ 以后的内置功能,一般直接调用函数 wp_tag_cloud 或者在
- 核心提示: 何时执行目标导向内容优化战略?当你确定目标,并有耐心评估网站表现时,这一战略就起作用。当然,这一过程可能花一些时间,需要不断进行
- 在维护公司内部网站时碰到一个实际问题——MIS主管要求将一些技术文件放在网页上,且只能让MIS 的员工浏览。这就涉及到如何对网页保密的问题。
- 一:GSA是什么?Google Search Appliance(简称:GSA)是由Google公司出品的一种机架设备。 Search Ap
- 第一步安装VMware,没什么值得注意的地方,不断下一步即可。我安装的是VMware10.0.7。VMware有个很好的功能--快照,它能把
- 1.更新yum源CentOS7默认yum源的PostgreSQL版本过低,不适合在本版本上使用。在https://yum.postgresq
- 步骤:终端运行sudo a2enmod程序提示可供激活的模块名称,输入:其中rewrite修改/etc/apache2/sites-enab
- 相信大多数朋友都是iframe木马的受害者,有朋友的网站被注入了n回iframe,心情可想而知。而且现在ARP攻击,注入iframe也是轻而
- CentOS 7 使用阿里云的yum源1. 备份原来的yum源sudo cp /etc/yum.repos.d/CentOS-Base.re
- 天下熙熙皆为利来,天下攘攘皆为利网(往)!当新一代中国商人爱上网络,当商人爱上商业搜索,世界将“利来利网”!网络经济,挟全球经济一体化的大潮
- 看到过很多做网站优化的朋友在写网站优化的文章的时候都总结过这样一条优化的经验如:不能用flash引导页,不能用图片或者flash做导航条,尽
- 杀死所有正在运行的容器docker kill $(docker ps -a -q) 删除所有已经停止的容器docker rm $(