docker实现redis集群(详解使用Docker进行Redis主从复制实践)
docker实现redis集群
详解使用Docker进行Redis主从复制实践目录
- 一、背景
- 二、操作步骤
- 三、安装Docker
- 四、主服务配置
- 五、从服务配置
- 六、结果验证
- 6.1 初步验证
- 6.2 同步检查
最近在做零信任安全网关,需要使用Redis作为认证缓存服务器,因为网关服务器分布在多个集群,每次都跨机房认证不太实现;所以需要使用Redis主从同步,将过程记录下来,希望可以给需要的同学一点参考。
- 安装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这个数据已经成功复制过来了。
到此这篇关于详解使用Docker进行Redis主从复制实践的文章就介绍到这了,更多相关Docker Redis主从复制内容请搜索开心学习网以前的文章或继续浏览下面的相关文章希望大家以后多多支持开心学习网!
- dockernextcloud优化(docker+nextcloud搭建个人云存储系统的实现)
- springbootdocker详解(Spring Boot 2.4 新特性之一键构建Docker镜像的过程详解)
- docker容器分配(Docker容器数据卷原理及使用方法解析)
- docker脚本指定linux(在docker中执行linux shell命令的操作)
- docker容器解决隔离的技术(Docker+selenium实现自动化健康报备的方法)
- docker指令详解(docker create命令的用法说明)
- docker容器启动自动执行命令(docker run 运行容器自动结束的解决)
- docker实现redis集群(详解使用Docker进行Redis主从复制实践)
- docker安装openoffice镜像(docker安装部署 onlyoffice的详细过程)
- dockerfile构建mysql镜像并初始化(docker-compose基于MySQL8部署项目的实现)
- docker安装教程图解(Docker在线、离线安装及其常用命令操作)
- docker redis安装配置(使用docker搭建redis主从的方法步骤)
- docker本地项目生成镜像(docker images本地迁移的实现)
- docker可用容量查看(docker 查看jvm内存占用方式)
- docker怎么增加端口(docker 添加端口及获取dockerfile的方法)
- docker怎么做数据(Docker数据卷常用操作代码实例)
- 大众推出了第五代高尔夫GT(大众推出了第五代高尔夫GT)
- 换代在即,现在是抄底 7.5代 高尔夫的最佳时机吗(换代在即现在是抄底)
- 2020年大众7.5代高尔夫R终结特别版 最后的呐喊(2020年大众7.5代高尔夫R终结特别版)
- 七年前的这部剧有毒,全剧只有女主红到发紫,男主至今无人认识(七年前的这部剧有毒)
- 宋轶除了演过于曼丽,原来还演过一个青楼女子(宋轶除了演过于曼丽)
- 赵丽颖第一部当女主的戏,主角配角个个都是实力演员(赵丽颖第一部当女主的戏)
热门推荐
- php递归ajax的交互模型(PHP使用反向Ajax技术实现在线客服系统详解)
- php添加数据到mysql数据库(PHP通过代码连接XAMPP数据库及MySQL数据库方法)
- python语言案例教程单元测试(Python单元和文档测试实例详解)
- snmp配置实例(SNMP4J服务端连接超时问题解决方案)
- nginx http转https配置(Nginx配置并兼容HTTP实现代码解析)
- apache2.4支持php5.5吗(WINDOWS下php5.2.4+mysql6.0+apache2.2.4+ZendOptimizer-3.3.0配置)
- SQL Server获取时间段内的所有月份
- mysql 索引表空间(MySQL如何构建数据表索引)
- php获取socket连接的详细信息(php使用socket调用http和smtp协议实例小结)
- vuejs组件使用教程交流(Vue vee-validate插件的简单使用)
排行榜
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9