掌握Docker-compose安装Redis主从集群
单节点Redis的主装R主并发能力是有上限的,要进一步提高Redis的从集并发能力,就需要搭建主从集群,群原实现读写分离
主节点: 可以对Redis实现读写操作从节点: 只可以对Redis实现读操作搭建的理讲主从集群结构如图如下:
图片
共包含三个节点,一个主两个从。解和集群这里我们会在同一台虚拟机中开启3个redis实例,主装R主模拟主从集群,从集信息如下:
IP
PORT
角色
192.168.150.102
6380
master
192.168.150.102
6381
slave
192.168.150.102
6382
slave
因为已经学习过Docker,群原所以使用Docker技术安装Rdis主从集群
Linux 上我们可以从 Github 上下载它的二进制包来使用,选择适应Docker版本的理讲docker compose,使用Docker info 查看Docker对应的Docker-Compose版本,我的机器对应的是源码下载v2.21.0
复制docker info1. 【步骤二】:下载Docker-Compose对应的稳定版本将Docker-Compose下载后,放在/usr/local/bin/目录下
复制curl -L "https://github.com/docker/compose/releases/download/v2.21.0/docker-compose-$(uname -s)-$(uname -m)" -o /usr/local/bin/docker-compose1. 【步骤三】:将可执行权限应用于Docker-Compose二进制文件 复制chmod +x /usr/local/bin/docker-compose1. 【步骤四】:测试是解和集群否安装成功 复制docker-compose version1.结果:
复制[root@www ~]# docker-compose version Docker Compose version v2.21.01.2.
图片
如果您觉得本文不错,欢迎关注,主装R主点赞,收藏支持,您的从集关注是我坚持的动力!
要在同一台虚拟机开启3个实例,群原必须准备三份不同的理讲配置文件和目录,配置文件所在目录也就是解和集群工作目录。确保下面的配置已经更改(位置也别错)
复制# master ## 创建主节点的配置文件 mkdir -p /redis-master-slave/master/config /redis-master-slave/master/data cd /redis-master-slave/master/config/ curl -O -L http://download.redis.io/releases/redis-6.0.20.tar.gz tar -zxvf redis-6.0.20.tar.gz cp /redis-master-slave/master/config/redis-6.0.20/redis.conf /redis-master-slave/master/config/redis.conf sed -i s/bind 127.0.0.1/bind 0.0.0.0/ /redis-master-slave/master/config/redis.conf # slave-1 ## 创建从节点-1的配置文件 mkdir -p /redis-master-slave/slave-1/config /redis-master-slave/slave-1/data cd /redis-master-slave/slave-1/config/ cp /redis-master-slave/master/config/redis-6.0.20/redis.conf /redis-master-slave/slave-1/config/redis.conf sed -i s/bind 127.0.0.1/bind 0.0.0.0/ /redis-master-slave/slave-1/config/redis.conf # slave-2 ## 创建从节点-2的配置文件 mkdir -p /redis-master-slave/slave-2/config /redis-master-slave/slave-2/data cd /redis-master-slave/slave-2/config/ cp /redis-master-slave/master/config/redis-6.0.20/redis.conf /redis-master-slave/slave-2/config/redis.conf sed -i s/bind 127.0.0.1/bind 0.0.0.0/ /redis-master-slave/slave-2/config/redis.conf1.2.3.4.5.6.7.8.9.10.11.12.13.14.15.16.17.18.19.20.21.创建名称为docker-compose-redis-master-slave.yml用于安装Redis主从集群的docker-compose文件
复制version: 3 services: # 主 master: image: redis:6.0.20 # 镜像redis:6.0.20 container_name: redis-master # 容器名为redis-master restart: unless-stopped # 指定容器退出后的重启策略为始终重启,但是不考虑在Docker守护进程启动时就已经停止了的容器 command: redis-server /etc/redis/redis.conf --requirepass 123456 --appendonly no # 启动redis服务并添加密码为:123456,默认不开启redis-aof方式持久化配置 environment: # 设置环境变量,相当于docker run命令中的-e TZ: Asia/Shanghai LANG: en_US.UTF-8 volumes: # 数据卷挂载路径设置,将本机目录映射到容器目录 - "/redis-master-slave/master/data:/data" - "/redis-master-slave/master/config/redis.conf:/etc/redis/redis.conf" # `redis.conf`文件内容`http://download.redis.io/redis-stable/redis.conf` ports: # 映射端口 - "6380:6379" # 从1 slave1: image: redis:6.0.20 # 镜像redis:6.0.20 container_name: redis-slave-1 # 容器名为redis-slave-1 restart: unless-stopped # 指定容器退出后的重启策略为始终重启,但是不考虑在Docker守护进程启动时就已经停止了的容器 command: redis-server /etc/redis/redis.conf --requirepass 123456 --appendonly no --slaveof 192.168.150.102 6380 --masterauth 123456 # 启动redis服务并添加密码为:123456,默认不开启redis-aof方式持久化配置,连接并认证master节点 environment: # 设置环境变量,相当于docker run命令中的-e TZ: Asia/Shanghai LANG: en_US.UTF-8 volumes: # 数据卷挂载路径设置,将本机目录映射到容器目录 - "/redis-master-slave/slave-1/data:/data" - "/redis-master-slave/slave-1/config/redis.conf:/etc/redis/redis.conf" # `redis.conf`文件内容`http://download.redis.io/redis-stable/redis.conf` ports: # 映射端口 - "6381:6379" # 从2 slave2: image: redis:6.0.20 # 镜像redis:6.0.20 container_name: redis-slave-2 # 容器名为redis-slave-2 restart: unless-stopped # 指定容器退出后的重启策略为始终重启,但是不考虑在Docker守护进程启动时就已经停止了的容器 command: redis-server /etc/redis/redis.conf --requirepass 123456 --appendonly no --slaveof 192.168.150.102 6380 --masterauth 123456 # 启动redis服务并添加密码为:123456,默认不开启redis-aof方式持久化配置,连接并认证master节点 environment: # 设置环境变量,相当于docker run命令中的-e TZ: Asia/Shanghai LANG: en_US.UTF-8 volumes: # 数据卷挂载路径设置,将本机目录映射到容器目录 - "/redis-master-slave/slave-2/data:/data" - "/redis-master-slave/slave-2/config/redis.conf:/etc/redis/redis.conf" # `redis.conf`文件内容`http://download.redis.io/redis-stable/redis.conf` ports: # 映射端口 - "6382:6379"1.2.3.4.5.6.7.8.9.10.11.12.13.14.15.16.17.18.19.20.21.22.23.24.25.26.27.28.29.30.31.32.33.34.35.36.37.38.39.40.41.42.43.44.45. 1.4.1. 运行 -- 主从复制模式(主写从读)使用Docker-Compos运行edocker-compose-redis-master-slave.yml进行安装Redis主从集群
复制docker-compose -f docker-compose-redis-master-slave.yml -p redis up -d1. 1.4.2. 测试1.进入redis-master容器 复制docker exec -it redis-master redis-cli -h 192.168.150.102 -p 6380 -a 1234561. 2.查看集群状态 复制info replication1.
图片
图片
发现报错,因为从节点只能读取数据,不能谢数据
图片