网站运营
位置:首页>> 网站运营>> 详解使用Docker进行Redis主从复制实践

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

作者:汤青松  发布时间:2022-09-28 16:58:22 

标签:Docker,Redis,主从复制
目录
  • 一、背景

  • 二、操作步骤

  • 三、安装Docker

  • 四、主服务配置

  • 五、从服务配置

  • 六、结果验证

    • 6.1 初步验证

    • 6.2 同步检查

一、背景

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

二、操作步骤

  • 安装Docker

  • 主服务配置

  • 从服务配置

  • 验证同步效果

三、安装Docker

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


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

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

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

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


docker info

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

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

在上图中可以看到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

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

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

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


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

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

详解使用Docker进行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编辑窗口粘贴后,如下图所示

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

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


redis-server `/redis.conf

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

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

在上图中可以看到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

将配置样例复制进来之后,窗口如下所示

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

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


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

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

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

在上图中可以看到从库的Redis也安装完成了,接下来使用redis-server命令启动从库服务器,命令如下图所示


redis-server redis.conf

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

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

在上图中可以看到Redis已经启动完成,接下来就可以进行验证效果了

六、结果验证

验证方法主要是在主库中设置数据,观察从库是否也会同步更新;

6.1 初步验证

不过这种操作有点麻烦,我们最好是先检查一下从库的启动日志,查看启动日志的命令如下所示


cat /tmp/redis.log

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

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

在上图中的日志信息可以看到从库已经成功将主库信息复制到本地来了。

6.2 同步检查

虽然日志中提示成功了,不过是否成功主从同步还是要以实际效果为准,这里我回到主服务器的终端窗口,然后进入redis的命令控制台,进入控制台的命令如下所示


redis-cli -a 123123123

命令执行之后,就可以进行redis命令操作了,这里我设置一个test为123123的键值对,设置命令如下所示


set  test  123123

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

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

在上图中可以看到Redis已经提示设置键值对成功了,接下来我继续回到从库的终端窗口,然后进入Redis的控制台,执行命令如下所示


redis-cli -a 123123123

命令执行完毕之后,就可以通过keys命令查看当前从库的键值对,命令如下所示
keys *

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

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

在上图中可以看到test这个数据已经成功复制过来了。

来源:https://juejin.cn/post/6949904940311691271

0
投稿

猜你喜欢

  • 10月28日下午消息,电子商务巨头阿里巴巴今日在杭州宣布,阿里巴巴(中国)教育科技有限公司(以下简称“阿里学院”)正式揭牌成立。新成立的阿里
  • 如果你已经购买了一款服务器,但仍然觉得其“动力”不够强劲,不妨试试下面列出的几个办法,许多情况下,它们往往能够起到事半功倍的效果。1.增加内
  • 很多phpcms的用户有疑问为什么通过审核的文章在前台无法编辑了,文章链接后边显示灰色的 编辑|删除,其实这也是官方出于安全考虑才这么做的.
  • 这段时间发现学生做网站的越来越多,但大多数都没有做成。这里给出几点建议,期望对你有所帮助。学生建站,我觉得应该注意以下四点:一、找到自己的方
  • 今天来介绍有关Godaddy主机知识的Godaddy主机解析服务器地址部分,一地昂要认真看哦!过关帐户的默认域名服务器取决于建立托管的日期。
  • DEDECMS5.5刚出来,很多人都还没有用,我就先尝试了,(勇于做第一个吃螃蟹的人)呵呵~~,其实做好数据备份也没什么好怕的。正好公司网站
  • 图片说明:10月22日下午,土豆网总经理张晓运做客东方网嘉宾聊天室,就“中国视频网站的发展之路”等话
  • 北京时间11月3日早间消息,受新闻出版总署终止《魔兽世界》审批消息影响,网易(Nasdaq:NTES)股价周一在纳斯达克下跌2.41%。截至
  • 对从事SEO(搜索引擎优化)的朋友来说,最难的就是当遇到挫折和问题的时候。文章里将列举出几种典型的情况,主要关注那些不是被搜索引擎惩罚的情况
  • 今天一个朋友加我QQ谈IP与PV的关系,以下是我个人的理解。有不对的也请指教。个人觉得IP固然重要,但PV更重要,对一个想长久发展的正规站来
  • 北京时间2008年7月26消息,据国外媒体报道,最近,微软和一些亚洲研究机构一起提出新的搜索引擎Web页面等级排序方法BrowseRank。
  • 在这篇文章中,我将向你们介绍各种Exchange Server(ExchangeServer是微软公司开发的邮件服务程序)组件所使用的通信端
  • 各位站长好,以前给百度客服打过N次电话,每每问及近期收录相关事谊都不给允回答。今天又打了一次。接电话的是个男的,听声音好像未成年...(日小
  • Ask.com在搜索引擎市场增长迅猛,刚刚传出消息其将耗资1亿美元于两年内进入中国市场建立中文版,就个人感觉,Ask在用户体验方面整体上已经
  • 对于网络游戏,本人历来是不怎么喜欢,只因下载的客户端庞大。98年至今本人还一直保留着一款红色警戒游戏,既可以单机,也可以偶尔联网对垒一下。随
  • 关于GG的我只能写那么多了,写的不好别见怪~~~本文章是给新人看的,老鸟漂过就是了~~关于作弊本人提倡的是尽量不要作弊,但是往往有很多人做G
  • ppc,cpm,cpc是什么意思,你了解吗?sem 是舶来品,在做搜索引擎营销的时候,使用相关软件的时候,经常为用到一些称呼的缩写,下边总结
  • 推荐阅读:Linux rm 命令误删文件的恢复方法1. 在/home/username/ 目录下新建一个目录,命名为:.trash2.. 在
  • 1、问:当在浏览器中输入“http://IP地址”和输入“http://IP地址/”有什么差别吗?它们会做什么?答:没有差别!前一种格式浏览
  • 伟大网站之路无法规避的原则,这里有几个我想你无法规避的原则。1.抛弃委员会。历史上没有一家伟大网站是被三个以上的人所构设出的。没有一个。委员
手机版 网站运营 asp之家 www.aspxhome.com