Docker部署系列之Docker Compose安装Redis三主三从集群
总结/朱季谦
在日常开发或者编程当中,经常需要用到redis集群,若是按照传统的方式,一个机器一个机器搭建,难免过于繁琐,故而可以通过dock er-compose编排方式,快速搭建。我在搭建过程当中,将操作记录下来,方便以后需要搭建三主三从节点时,可以基于以前的成功经验,快速搭建起来。
一、环境准备
准备三台机器,在每台机器上,计划安装一个Redis主节点和一个Redis从节点。
| 机器 | Redis节点 | 节点端口 |
|---|---|---|
| 192.168.31.130 | redis-master/redis-slave | 6379/6380 |
| 192.168.31.131 | redis-master/redis-slave | 6379/6380 |
| 192.168.31.132 | redis-master/redis-slave | 6379/6380 |
二、文件准备
2.1、创建Redis节点目录
分别在192.168.31.130、192.168.31.131、192.168.31.132机器上,执行以下命令,创建Redis主从节点文件目录——
for dir in redis-master/data redis-slave/data; do mkdir -p "/opt/docker/redis-cluster/$dir";done
2.2、创建节点配置文件redis.conf
分别在192.168.31.130、192.168.31.131、192.168.31.132机器上的/opt/docker/redis-cluster/redis-master/与/opt/docker/redis-cluster/redis-slave/目录下,创建一个redis.conf文件,文件内容包括以下属性——
port 6379 #指定 Redis 服务器监听的端口号,这是客户端与 Redis 服务器进行通信的端口。
save 900 1#在给定时间间隔内有多少次写操作时,Redis 将执行自动的快照(生成 RDB 文件)。
save 300 10
save 60 10000
dbfilename dump.rdb#指定生成的 RDB 文件的名称。
dir /data #指定持久化文件的存储目录。
appendonly yes #启用 AOF(Append-Only File)持久化模式。
appendfilename "appendonly.aof" #指定 AOF 文件的名称。
appendfsync everysec #控制 AOF 缓冲区的内容何时同步到硬盘。这里的选项 everysec 表示每秒同步一次
cluster-enabled yes #启用 Redis 集群功能。
cluster-config-file nodes.conf #指定保存集群拓扑信息的配置文件名。
cluster-node-timeout 5000 #设置节点间通信的超时时间,单位为毫秒。
快捷指令,直接在linux运行——
for dir in redis-master redis-slave; do
if [ "$dir" == "redis-master" ]; then
port=6379
elif [ "$dir" == "redis-slave" ]; then
port=6380
fi
echo "port $port
save 900 1
save 300 10
save 60 10000
dbfilename dump.rdb
dir /data
appendonly yes
appendfilename "appendonly.aof"
appendfsync everysec
cluster-enabled yes
cluster-config-file nodes.conf
cluster-node-timeout 5000" > /opt/docker/redis-cluster/$dir/redis.conf;done
运行完成后,在/opt/docker/redis-cluster/redis-master/以及/opt/docker/redis-cluster/redis-slave/生成一个data目录和一个redis.conf文件——
redis.conf文件里内容就是前面设置的。
三、编写docker-compose.yml编排文件
分别在三台机器的/opt/docker/redis-cluster/目录下,创建docker-compose.yml文件,内容如下:
version: '3.1'
services:
redis-master:
image: redis:5.0.8
contAIner_name: redis-master
restart: always
network_mode: "host"
volumes:
- /opt/docker/redis-cluster/redis-master/data:/data
- /opt/docker/redis-cluster/redis-master/redis.conf:/usr/local/etc/redis/redis.conf
command: ["redis-server","/usr/local/etc/redis/redis.conf"]
redis-slave:
image: redis:5.0.8
container_name: redis-slave
restart: always
network_mode: "host"
volumes:
- /opt/docker/redis-cluster/redis-slave/data:/data
- /opt/docker/redis-cluster/redis-slave/redis.conf:/usr/local/etc/redis/redis.conf
command: [ "redis-server","/usr/local/etc/redis/redis.conf" ]
完成后,执行指令docker-compose up -d——
执行指令docker ps -a查看一下容器是否已经正常运行,如下现实证明没有问题——
四、执行指令组建redis集群
4.1、任意一台机器上,执行以下指令,进入到docker容器当中——
docker exec -it redis-master bash #redis-master对应的是docker ps -a查看到的容器名redis-master
4.2、创建集群
redis-cli --cluster create 192.168.31.130:6379 192.168.31.130:6380 192.168.31.131:6379 192.168.31.131:6380 192.168.31.132:6379 192.168.31.132:6380 --cluster-replicas 1
执行完成后,打印日志如下——
执行指令后,会出现提示“Can I set the above configuration? (type 'yes' to accept):”,这里输入yes,回车。出现以下情况话,就是已经成功创建redis集群了——
可以通过以下指令进入到redis客户端,查看集群情况——
root@hadoop1:/data# redis-cli -c -h 192.168.31.130 -p 6379
然后,执行指令cluster info查看集群状况,显示cluster_state:ok则表示集群已经正常创建。
当然,可以进一步通过cluster nodes指令,查看各节点状况,已经是三主三从的集群状况了——
以上,就是整个集群搭建过程。
若是之前没有玩过Docker的朋友,可以参考我之前的一篇Docker搭建记录文章《CentOS7安装Docker遇到的问题笔记》
作者:朱季谦出处:https://www.cnblogs.com/zhujiqian/
本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须在文章页面给出原文链接,否则保留追究法律责任的权利。
您可能感兴趣的文章
- 12-20Kubernetes中使用临时容器进行故障排查的方法
- 12-20Nginx设置HTTPS的方法步骤
- 12-20二进制方式安装 Kubernetes1.18.3版本实现脚本
- 12-20Nginx工作模式及代理配置的使用细节
- 12-20ZooKeeper分布式协调服务设计核心概念及安装配置
- 12-20Kubernetes部署可视化地图的十个步骤
- 12-20关于docker清理Overlay2占用磁盘空间的问题(亲测有效)
- 12-20Docker compose配置文件写法及命令使用示例
- 12-20openwrt安装docker并启动的操作方法
- 12-20云原生Kubernetes初始化容器Init使用教程


阅读排行
推荐教程
- 12-07一文教你怎么选择Tomcat对应的JDK版本
- 12-07新版Eclipse集成Tomcat时找不到server选项的解决方法
- 12-06IIS7 应用程序池自动回收关闭的解决方案
- 12-05Windows Server 2019安装VMware
- 12-05Windows服务器默认IE浏览器无法下载文件的解决方法
- 12-05Docker安装Jenkins全过程
- 12-19Zabbix SAML SSO 登录绕过漏洞的操作流程
- 12-15Docker-Compose搭建Spark集群的实现方法
- 12-14Docker Desktop无法正常启动解决(failed to start...)
- 12-14k8s 与docker空间使用分析与清理方法





