您现在的位置是:首页 >技术杂谈 >在Linux系统下基于Docker搭建Redis集群网站首页技术杂谈

在Linux系统下基于Docker搭建Redis集群

阮清语 2024-07-20 12:01:04
简介在Linux系统下基于Docker搭建Redis集群

创建镜像

#部署Redis集群,该集群有3个节点; --cluster-enabled yes允许启用集群; 
docker create --name redis-node--01 --net host -v /data/redis-data/node1:/data redis:5.0.5 --cluster-enabled yes --cluster-config-file  redis-node--01.conf --port 6379

docker create --name redis-node--02 --net host -v /data/redis-data/node2:/data redis:5.0.5 --cluster-enabled yes --cluster-config-file  redis-node--02.conf --port 6380

docker create --name redis-node--03 --net host -v /data/redis-data/node3:/data redis:5.0.5 --cluster-enabled yes --cluster-config-file  redis-node--03.conf --port 6381

 #启动容器 
 docker start redis-node--01 redis-node--02 redis-node--03  
(docker ps -a是查看docker下所有的容器)

此时我们通过docker inspect 容器id命令看到的各个redis容器的IP地址为空

因为使用的是HOST模式启动的容器,容器ip和主机共享,为101.33.200.207

配置Linux防火墙(配置方法如下:)
1、查看防火墙状态

systemctl status firewalld

2、如果不是显示active状态(或者如果是dead状态)说明防火墙未开启,需要打开防火墙

systemctl start firewalld

3、# 查看所有已开放的临时端口(默认为空)

firewall-cmd --list-ports

查看所有永久开放的端口(默认为空)

firewall-cmd --list-ports --permanent

添加永久开放的端口(示例:开放223端口)(注意:此处我们需要开放6379、6380、6381、16379、16380、16381一共六个端口)

firewall-cmd --add-port=223/tcp --permanent

关闭永久端口

firewll-cmd --remove-port=80/tcp --permanent

配置结束后需要输入重载命令并重启防火墙以生效配置

firewall-cmd --reload
systemctl restart firewalld

使用Docker搭建Redis集群的时候,在redis-cli --cluster create环节,一直卡到"Waiting for
the cluster to join”环节。百思不得其解,后续通过Redis官网,耗费一段时间后,才得以解决。

Redis集群中的各个节点,需要开放一个端口,同其他节点建立连接,用于接收心跳数据等操作。也就是说,redis-node1节点,开放6379端口供client连接时,同时提供16379端口(10000

  • 6379),供其他Redis节点连接。比如我们此处使用的三个节点的端口分别为6379、6380、6381,所以此时需要将6379、6380、6381开启之外,还要开启端口16379、16380、16381用于节点之间的通信。(注意如果使用的是云服务器,还需要在阿里云安全组
    或 腾讯云服务器控制台防火墙中,开放6379、6380、6381、16379、16380、16381六个端口)

集群初始化过程中,需要同其他Redis建立连接,进行通信。若节点间无法连接,此时会阻塞,这也就是一直阻塞到"Waiting for the
cluster to join"环节的原因。

细心的读者,不难发现,上述给出Redis节点创建命令,通过–net
host,指定网络类型为host,使得容器与宿主机使用同一网络,从而规避了这类问题。
————引用自:https://blog.csdn.net/weixin_46053046/article/details/120102997

 #进入redis-node01容器进行操作(docker exec -it 容器名称  /bin/bash进入容器终端并且的保留为容器终端的输入形式(-it和bash的结合作用))
docker exec -it redis-node--01 /bin/bash
 #启动集群
redis-cli --cluster create 101.33.200.207:6379 101.33.200.207:6380 101.33.200.207:6381 --cluster-replicas 0
 #注意--cluster-replicas 0意思是设置为0个子节点

启动完成如下所示:

此时进入第一个节点的redis服务:redis-cli -h 101.33.200.207 -p 6380 -c
-c的意思是允许集群重定向,比如我在6380上操作,它可能重定向到6381上去,这就是集群下的操作
执行命令 CLUSTER NODES,发现问题,每个节点中的当前节点的ip都变成了10.0.20.14

这是不对的。
以redis-node–01容器为例:

  1. 首先下载VIM编辑器:先执行apt-get update,完毕后执行apt-get install vim。
  2. 退出redis控制台,到容器层,输入Linux指令ls,发现有配置文件redis-node–01.conf。
  3. 使用vim redis-node–02.conf,将配置文件中的10.0.20.14 改为 公网ip 101.33.200.207。
  4. 执行命令:redis-cli -a cyclone -c -h 101.33.200.207 -p 6379 shutdown停止redis集群中的当前节点。
  5. 发现此时退出到了容器外。
  6. 此时根据容器id,重新start容器,此redis节点会自己重新加入集群。
  7. 再进入容器。
  8. 再输入redis-cli -c进入Redis控制台
  9. 再输入cluster nodes,发现当前节点的ip正常了。

以上操作redis-node–01、redis-node–02、redis-node–03,三个容器都要操作。
测试集群是否可用:

Redis集群搭建完成。
可以在外部使用当前主机ip+端口连接redis了。

注意:redis容器重启后,需要删除xxx.aof、xxx.rdb、xxx.conf三个文件,才能重新启动集群。

风语者!平时喜欢研究各种技术,目前在从事后端开发工作,热爱生活、热爱工作。