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

本文涉及的产品
云数据库 Tair(兼容Redis),内存型 2GB
Redis 开源版,标准版 2GB
推荐场景:
搭建游戏排行榜
日志服务 SLS,月写入数据量 50GB 1个月
简介: 最近在做零信任安全网关,需要使用Redis作为认证缓存服务器,因为网关服务器分布在多个集群,每次都跨机房认证不太实现;所以需要使用Redis主从同步,将过程记录下来,希望可以给需要的同学一点参考。

一、背景


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


二、操作步骤


  1. 安装Docker
  2. 主服务配置
  3. 从服务配置
  4. 验证同步效果


三、安装Docker


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


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


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


1.png


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


docker info


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


2.png


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


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


3.png


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


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


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


4.png


从上图中可以看到,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编辑窗口粘贴后,如下图所示


5.png


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


redis-server `/redis.conf


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


6.png


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


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


7.png


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


接着安装Redis服务,安装命令如下所示


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


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


8.png


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


redis-server redis.conf


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


9.png


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


六、结果验证


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


6.1 初步验证


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


cat /tmp/redis.log


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


10.png


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


6.2 同步检查


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


redis-cli -a 123123123


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


set  test  123123


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


11.png


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


redis-cli -a 123123123


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


keys *


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


12.png


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

相关实践学习
基于Redis实现在线游戏积分排行榜
本场景将介绍如何基于Redis数据库实现在线游戏中的游戏玩家积分排行榜功能。
云数据库 Redis 版使用教程
云数据库Redis版是兼容Redis协议标准的、提供持久化的内存数据库服务,基于高可靠双机热备架构及可无缝扩展的集群架构,满足高读写性能场景及容量需弹性变配的业务需求。 产品详情:https://www.aliyun.com/product/kvstore     ------------------------------------------------------------------------- 阿里云数据库体验:数据库上云实战 开发者云会免费提供一台带自建MySQL的源数据库 ECS 实例和一台目标数据库 RDS实例。跟着指引,您可以一步步实现将ECS自建数据库迁移到目标数据库RDS。 点击下方链接,领取免费ECS&RDS资源,30分钟完成数据库上云实战!https://developer.aliyun.com/adc/scenario/51eefbd1894e42f6bb9acacadd3f9121?spm=a2c6h.13788135.J_3257954370.9.4ba85f24utseFl
目录
相关文章
|
2月前
|
Kubernetes Devops 持续交付
DevOps实践:使用Docker和Kubernetes实现持续集成和部署网络安全的守护盾:加密技术与安全意识的重要性
【8月更文挑战第27天】本文将引导读者理解并应用DevOps的核心理念,通过Docker和Kubernetes的实战案例,深入探讨如何在现代软件开发中实现自动化的持续集成和部署。文章不仅提供理论知识,还结合真实示例,旨在帮助开发者提升效率,优化工作流程。
|
6天前
|
Linux 持续交付 Docker
掌握Docker:从入门到实践
Docker 是一个开源容器引擎,允许开发者将应用及其依赖打包成可移植的容器,在任意 Linux 机器上运行。本文从基本概念入手,详细介绍 Docker 的安装、基本操作、镜像构建及 Docker Compose 的使用,并通过实战案例展示如何部署 Web 应用、构建微服务架构及实现 CI/CD。通过学习,你将掌握 Docker 的核心功能,提升应用开发和部署效率。
|
19天前
|
Linux iOS开发 Docker
Docker:容器化技术的领航者 —— 从基础到实践的全面解析
在云计算与微服务架构日益盛行的今天,Docker作为容器化技术的佼佼者,正引领着一场软件开发与部署的革命。它不仅极大地提升了应用部署的灵活性与效率,还为持续集成/持续部署(CI/CD)提供了强有力的支撑。
201 69
|
10天前
|
Kubernetes Cloud Native Docker
云原生时代的容器化实践:Docker与Kubernetes入门
【9月更文挑战第30天】在云计算的浪潮中,云原生技术正以前所未有的速度重塑着软件开发和运维领域。本文将通过深入浅出的方式,带你了解云原生的核心组件——Docker容器和Kubernetes集群,并探索它们如何助力现代应用的构建、部署和管理。从Docker的基本命令到Kubernetes的资源调度,我们将一起开启云原生技术的奇妙之旅。
|
14天前
|
Cloud Native 持续交付 Docker
云原生技术入门与实践:Docker容器化部署示例
【9月更文挑战第25天】在数字化转型的浪潮下,云原生技术成为推动企业创新的重要力量。本文旨在通过浅显易懂的语言,为初学者揭示云原生技术的核心概念及其应用价值。我们将以Docker容器为例,逐步引导读者了解如何将应用程序容器化,并在云端高效运行。这不仅是对技术趋势的跟随,更是对资源利用和开发效率提升的探索。
41 4
|
1月前
|
NoSQL 关系型数据库 Redis
mall在linux环境下的部署(基于Docker容器),Docker安装mysql、redis、nginx、rabbitmq、elasticsearch、logstash、kibana、mongo
mall在linux环境下的部署(基于Docker容器),docker安装mysql、redis、nginx、rabbitmq、elasticsearch、logstash、kibana、mongodb、minio详细教程,拉取镜像、运行容器
mall在linux环境下的部署(基于Docker容器),Docker安装mysql、redis、nginx、rabbitmq、elasticsearch、logstash、kibana、mongo
|
22天前
|
运维 Ubuntu Linux
深入理解并实践Docker容器化技术
深入理解并实践Docker容器化技术
49 6
|
26天前
|
Devops jenkins 持续交付
DevOps实践:构建和部署一个Docker化的应用
【9月更文挑战第14天】在当今快节奏的软件开发领域,DevOps已经成为提升效率、加速交付的关键。本文将引导你理解DevOps的核心概念,并通过一个实际的示例—构建和部署一个Docker化的应用—来深入探讨其实践方法。我们将从简单的应用出发,逐步实现Docker容器化,并最终通过CI/CD流水线自动化部署过程。这不仅是对DevOps流程的一次实操演练,也是对现代软件开发理念的一次深刻体验。
|
1月前
|
Cloud Native 持续交付 Docker
云原生技术实践:Docker容器化部署教程
【9月更文挑战第4天】本文将引导你了解如何利用Docker这一云原生技术的核心工具,实现应用的容器化部署。文章不仅提供了详细的步骤和代码示例,还深入探讨了云原生技术背后的哲学,帮助你理解为何容器化在现代软件开发中变得如此重要,并指导你如何在实际操作中运用这些知识。
|
13天前
|
NoSQL 网络协议 Redis
Redis的主从复制和哨兵模式
本文详细介绍了Redis的主从复制配置、原理(包括全量复制和增量复制)以及如何搭建一主二从的Redis集群,同时还探讨了Redis哨兵模式的概念、配置文件、以及如何配置一主二从三哨兵的Redis哨兵模式,以实现高可用性。