一、前言

redis集群对于很多人来说非常熟悉,在前些日子,我也有一位大兄弟也发布过一篇关于在阿里云(centOS7)上搭建redis 集群的文章,虽然集群搭建的文章在网上很多,我比较喜欢这篇文章的地方是他在搭建过程中,指出一些我们会遇到而别人没有指出的问题。

在这里,我同样带给大家一遍关于阿里云(centOS7)redis集群搭建的文章,但是这次搭建有所不同的是,它是在docker上搭建的redis集群。

环境说明

采用单机部署

操作系统 ip docker版本 redis版本
centos 7.6 192.168.31.150

19.03.5

4.0.10

二、准备镜像

docker pull redis:4.0.
docker pull ruby

说明:ruby用是来做加入集群的用的,仅一次使用。

三、搭建

创建redis配置文件

mkdir -p /data/redis-cluster
vi /data/redis-cluster/redis-cluster.tmpl

内容如下:

port ${PORT}
protected-mode no
cluster-enabled yes
cluster-config-file nodes.conf
cluster-node-timeout
cluster-announce-ip 192.168.31.150
cluster-announce-port ${PORT}
cluster-announce-bus-port ${PORT}
appendonly no

注意:ip地址修改为本机ip

配置文件解释

port ${PORT}                        ##节点端口
protected-mode no #关闭protected-mode模式,外部网络可以直接访问
cluster-enabled yes ##cluster集群模式
cluster-config-file nodes.conf ##集群配置名
cluster-node-timeout ##超时时间
cluster-announce-ip 192.168.31.150 ##实际为各节点网卡分配ip 先用上网关ip代替
cluster-announce-port ${PORT} ##节点映射端口
cluster-announce-bus-port ${PORT} ##节点总线端
appendonly no ##持久化模式

备注:此模版文件为集群节点通用文件 其中${PORT} 将读取命令行变量

创建自定义network

docker network create redis-net

生成配置文件

生成conf和data目录,并生成配置信息

for port in `seq  `; do \
mkdir -p ./${port}/conf \
&& PORT=${port} envsubst < ./redis-cluster.tmpl > ./${port}/conf/redis.conf \
&& mkdir -p ./${port}/data; \
done

共生成6个文件夹,从7000到7005,每个文件夹下包含data和conf文件夹,同时conf里面有redis.conf配置文件

创建容器

创建6个redis容器

for port in `seq  `; do \
docker run -d -ti -p ${port}:${port} -p ${port}:${port} \
-v /data/redis-cluster/${port}/conf/redis.conf:/usr/local/etc/redis/redis.conf \
-v /data/redis-cluster/${port}/data:/data \
--restart always --name redis-${port} --net redis-net \
--sysctl net.core.somaxconn= redis:4.0. redis-server /usr/local/etc/redis/redis.conf; \
done

至此,通过命令docker ps可查看刚刚生成的6个容器信息

四、创建集群

通过启动ruby来实现集群

echo yes | docker run -i --rm --net redis-net ruby sh -c '\
gem install redis \
&& wget http://download.redis.io/releases/redis-4.0.10.tar.gz \
&& tar xvf redis-4.0..tar.gz && cd redis-4.0./src \
&& ruby redis-trib.rb create --replicas \
'"$(for port in `seq 7000 7005`; do \
echo -n "$(docker inspect --format '{{ (index .NetworkSettings.Networks "redis-net").IPAddress }}' "redis-${port}")":${port} ' ' ; \
done)"

它其实就是调用了命令:

ruby redis-trib.rb create --replicas 1 172.18.0.2:7000  172.18.0.3:7001  172.18.0.4:7002  172.18.0.5:7003  172.18.0.6:7004  172.18.0.7:7005  

输出如下:

...
>>> Assign a different config epoch to each node
>>> Sending CLUSTER MEET messages to join the cluster
Waiting for the cluster to join..
>>> Performing Cluster Check (using node 172.18.0.2:)
M: a779c88a19a2582620d0a1ad3f90431f92f91af5 172.18.0.2:
slots:- ( slots) master
additional replica(s)
M: 880a2b0671d0ff15192e758ff7204ccf15f52cd0 192.168.31.150:
slots:- ( slots) master
additional replica(s)
S: 3b04d5b6bcd86efaaceb2002087729bcb9bb1c07 192.168.31.150:
slots: ( slots) slave
replicates 5e33b75081c76bfc677e1941fdc2577709280f77
M: 5e33b75081c76bfc677e1941fdc2577709280f77 192.168.31.150:
slots:- ( slots) master
additional replica(s)
S: dad167c467186794e5095b58a0f43e443ff692fb 192.168.31.150:
slots: ( slots) slave
replicates 880a2b0671d0ff15192e758ff7204ccf15f52cd0
S: fa3775cbcdd0512de4fe2c208de1046b5369e0b3 192.168.31.150:
slots: ( slots) slave
replicates a779c88a19a2582620d0a1ad3f90431f92f91af5
[OK] All nodes agree about slots configuration.
>>> Check for open slots...
>>> Check slots coverage...
[OK] All slots covered.

能看到3主3从,说明集群成功了。

查看集群信息

# docker exec -it redis-7000 /bin/bash -c "redis-cli -p 7000 cluster nodes"
880a2b0671d0ff15192e758ff7204ccf15f52cd0 192.168.31.150:@ master - connected -
3b04d5b6bcd86efaaceb2002087729bcb9bb1c07 192.168.31.150:@ slave 5e33b75081c76bfc677e1941fdc2577709280f77 connected
5e33b75081c76bfc677e1941fdc2577709280f77 192.168.31.150:@ master - connected -
dad167c467186794e5095b58a0f43e443ff692fb 192.168.31.150:@ slave 880a2b0671d0ff15192e758ff7204ccf15f52cd0 connected
fa3775cbcdd0512de4fe2c208de1046b5369e0b3 192.168.31.150:@ slave a779c88a19a2582620d0a1ad3f90431f92f91af5 connected
a779c88a19a2582620d0a1ad3f90431f92f91af5 192.168.31.150:@ myself,master - connected -

测试写入和读取

# docker exec -it redis-7000 /bin/bash
127.0.0.1:> set a 123
-> Redirected to slot [] located at 192.168.31.150:
OK
192.168.31.150:> get a
“”
192.168.31.150:>

本文参考链接:
https://www.cnblogs.com/lianggp/articles/8136222.html
https://blog.csdn.net/qq_22211217/article/details/80436996

注意:参考链接中的redis-trib.rb,不能使用了。已经更新了!

所以,必须得用redis源码中的redis-trib.rb

docker redis4.0集群搭建的更多相关文章

  1. docker redis4.0 集群(cluster)搭建

    前言 redis集群对于很多人来说非常熟悉,在前些日子,我也有一位大兄弟也发布过一篇关于在阿里云(centOS7)上搭建redis 集群的文章,虽然集群搭建的文章在网上很多,我比较喜欢这篇文章的地方是 ...

  2. Docker Swarm redis 集群搭建

    Docker Swarm redis 集群搭建 环境1: 系统:Linux Centos 7.4 x64 内核:Linux docker 3.10.0-693.2.2.el7.x86_64 Docke ...

  3. Redis 3.0 集群搭建

    Redis 3.0 集群搭建 开启两个虚拟机 分别在两个虚拟机上开启3个Redis实例 3主3从两个虚拟机里的实例互为主备 下面分别在两个虚拟机上安装,网络设置参照codis集群的前两个主机 分别关闭 ...

  4. Redis 5.0 集群搭建

    Redis 5.0 集群搭建 单机版的 Redis 搭建 https://www.jianshu.com/p/b68e68bbd725 /usr/local/目录 mkdir redis-cluste ...

  5. Ubuntu 12.04下Hadoop 2.2.0 集群搭建(原创)

    现在大家可以跟我一起来实现Ubuntu 12.04下Hadoop 2.2.0 集群搭建,在这里我使用了两台服务器,一台作为master即namenode主机,另一台作为slave即datanode主机 ...

  6. Docker下ETCD集群搭建

    搭建集群之前首先准备两台安装了CentOS 7的主机,并在其上安装好Docker. Master 10.100.97.46 Node 10.100.97.64 ETCD集群搭建有三种方式,分别是Sta ...

  7. centos7/rhel7下安装redis4.0集群

    相关介绍:Redis从3.0版本开始支持集群! 集群一般由多个节点组成,节点数量至少6个才能保证组成完整高可用的集群. 每个节点需要开启配置文件中的cluster-enabled yes,让Redis ...

  8. centos下hadoop2.6.0集群搭建详细过程

    一 .centos集群环境配置 1.创建一个namenode节点,5个datanode节点 主机名 IP namenodezsw 192.168.129.158 datanode1zsw 192.16 ...

  9. redis3.0集群搭建

    生产环境中准备使用redis3.0集群了,花了一天时间研究了一下,下面记录一下集群搭建的过程. 服务器规划: 192.168.116.129    7000,7003 192.168.116.130 ...

随机推荐

  1. SIT系统整合测试

    System Integrate Test的缩写,即系统整合测试      系统整合测试就是评估产品在其规格范围内的环境下工作,能否完成产品设计规格所需要的功能及与周边设备.应用软件的兼容性.大致可以 ...

  2. js读取sqlserver数据库,输出至html

    代码: <!DOCTYPE html> <html> <head>   <meta charset="utf-8">   <m ...

  3. 浅谈 HTTP协议

    1.什么是http协议Hyper Text Transport Portocal(超文本传输协议)HTTP协议是应用层协议浏览器和web服务器通讯时遵守的约定互联网使用最多的协议提供超文本的传输服务通 ...

  4. spring(一)IOC & AOP

    参考文档: spring详解:http://www.cnblogs.com/ysocean/p/7466191.html(可以说非常详细了) aop源码详解:https://www.cnblogs.c ...

  5. linux 上使用yum 安装openjdk1.8

    使用yum查找jdk: yum search java|grep jdk # yum search java|grep jdk ldapjdk-javadoc.noarch : Javadoc for ...

  6. 【面向对象】第四单元总结——UML

    本单元构架设计 统一建模语言(英语:Unified Modeling Language,缩写 UML)是非专利的第三代建模和规约语言.UML是一种开放的方法,用于说明.可视化.构建和编写一个正在开发的 ...

  7. maven 工具

    maven 工具 1.打包:mvn clean package 2.打包并安装到本地仓库:mvn clean install 3.利用maven下载源代码:mvn dependency:sources ...

  8. SVN更新冲突文件冲突符号的意思

    带黄色感叹号的文件为冲突文件,内容会发生变化并且会存在一些特殊符号: <<<<<<< .mine#Mon Feb 18 20:10:37 CST 2013== ...

  9. 运维笔记--Docker文件占用磁盘空间异常处理

    场景描述: 1. 服务器运行一段时间后,发现系统盘磁盘空间在不断增加,一开始的时候,不会影响系统,随着时间的推移,磁盘空间在不断增加,直到有一天你会发现系统盘剩余空间即将使用完,值得庆幸的是,如果您使 ...

  10. WebGL学习笔记(十六):遮罩

    这里总结下几种WebGL中实现遮罩的方法. 模板缓冲 模板缓冲可以实现渲染剔除,但是我们之前的学习里,剔除范围是基于上一次渲染的结果,且上一次的渲染也会进行显示,这样的话并不适合用来实现遮罩. 我们想 ...