首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Docker搭建Redis集群

Docker搭建Redis集群

原创
作者头像
逸轩
发布2022-07-29 14:45:51
7451
发布2022-07-29 14:45:51
举报
文章被收录于专栏:Linux系统Linux系统

前提:

1、在服务器的安全组和防火墙中放通相对应的端口,操作系统:centos 7.6,需要放通9000端口

2、登录自己的Linux系统服务器

3、关闭服务器内部的firewalld防火墙

4、开启内核端口转发:

通过vim /etc/sysctl.conf把里面的net.ipv4.ip_forward = 0修改为net.ipv4.ip_forward = 1后进行保存退出,通过sysctl -p命令使修改后的内核转发文件生效

5、下载安装好docker

6、安装配置好镜像加速源(由于正常拉取镜像是从境外的docker官网拉取,建议设置镜像加速源) :

轻量应用服务器 安装 Docker 并配置镜像加速源 - 最佳实践 - 文档中心 - 腾讯云 (tencent.com)

第一步:拉取镜像

docker pull redis:5.0.5

第二步:创建Redis容器

创建三个 redis 容器:

redis-node1:6379

redis-node2:6380

redis-node3:6381

docker create --name redis-node1 -v /data/redis-data/node1:/data -p 6379:6379 redis:5.0.5 --cluster-enabled yes --cluster-config-file nodes-node-1.conf docker create --name redis-node2 -v /data/redis-data/node2:/data -p 6380:6380 redis:5.0.5 --cluster-enabled yes --cluster-config-file nodes-node-2.conf docker create --name redis-node3 -v /data/redis-data/node3:/data -p 6381:6379 redis:5.0.5 --cluster-enabled yes --cluster-config-file nodes-node-3.conf

第三步:启动容器并创建集群

通过命令docker start $(docker ps -aq) 或者使用docker start redis-node1 redis-node2 redis-node3 来启动3个Redis容器:

第一种:

第二种:

执行完运行命令后检查一下容器的启动情况:

如果出现上图情况,Exited (1) 3 seconds ago,可以通过 docker logs 查看:

如上提示的是权限问题,我们尝试修改一下权限:

chmod -R 777 /data

重新启动成功后如下图所示:

组建集群

查看3个Redis在Docker中分配的ip结点信息: docker inspect redis-node1 | grep IPAddress docker inspect redis-node2 | grep IPAddress docker inspect redis-node3 | grep IPAddress

接下来进入redis-node1这个个容器进行组建集群:

docker exec -it redis-node1 /bin/bash

redis-cli --cluster create 172.17.0.2:6379 172.17.0.3:6379 172.17.0.4:6379 --cluster-replicas 0

ok,此时集群搭建完了,我们接下来测试一下。

测试集群:

使用 redis-cli -c 命令连接到集群结点,然后 set 值(这个值是容器启动的ID号),set 值之后会自动重定向到 0.2 ip地址,然后通过 get 获取一下,获取成功证明集群有效。

第四步:存在的问题和修复方案

按照如上的步骤,虽然集群搭建成功了,但其实还是有点问题的,由于集群节点中的 ip地址 是docker内部分配的,如:172.17.0.2 等,如果使用 redis集群 的项目跟集群不在一台服务器上,那么项目是没法使用集群的,因为是访问不通的。

解决方案:一种解决方案是让Docker使用 host模式 的网络连接类型,Docker在使用host模式下创建的容器是没有自己独立的网络命名空间的,是跟物理机共享一个网络空间,进而可以共享物理机的所有端口与IP,这样就可以让公共网络直接访问容器了,尽管这种方式有安全隐患,但目前来说还没找到其他可行性模式。

就存在的问题我们重新采用 host模式,重新创建一下容器:

1、停止已运行的容器

docker stop redis-node1 redis-node2 redis-node3

2、删除之前创建的容器

docker rm redis-node1 redis-node2 redis-node3

3、重新基于host模式创建

docker create --name redis-node1 --net host -v /data/redis-data/node1:/data redis:5.0.5 --cluster-enabled yes --cluster-config-file nodes-node-1.conf --port 6379 docker create --name redis-node2 --net host -v /data/redis-data/node2:/data redis:5.0.5 --cluster-enabled yes --cluster-config-file nodes-node-2.conf --port 6380 docker create --name redis-node3 --net host -v /data/redis-data/node3:/data redis:5.0.5 --cluster-enabled yes --cluster-config-file nodes-node-3.conf --port 6381 跟之前创建命令不同,一是指定了 --net 网络类型为 host,二是这种情况下就不需要端口映射了,比如 -p 6379:6379,因为此时需要对外共享容器端口服务,所以只需要指定对外暴露的端口 -p 6379-p 6380 等。

4、启动容器并组建集群

docker start redis-node1 redis-node2 redis-node3

docker exec -it redis-node1 /bin/bash

redis-cli --cluster create 10.211.55.4:6379 10.211.55.4:6380 10.211.55.4:6381 --cluster-replicas 0

5、查看集群信息

redis-cli

cluster nodes

6、测试集群:使用 redis-cli -c 连接到集群上,set一个值,然后从其他节点再获取值查看是否成功:

redis-cli -c

set wxiaowei 123

get wxiaowei

至此,本次基于Docker的Redis集群单副本模式算是搭建好了,文中3个redis都是用的主节点

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 前提:
  • 第一步:拉取镜像
    • docker pull redis:5.0.5
    • 第二步:创建Redis容器
      • 创建三个 redis 容器:
        • redis-node1:6379
          • redis-node2:6380
            • redis-node3:6381
              • docker create --name redis-node1 -v /data/redis-data/node1:/data -p 6379:6379 redis:5.0.5 --cluster-enabled yes --cluster-config-file nodes-node-1.conf docker create --name redis-node2 -v /data/redis-data/node2:/data -p 6380:6380 redis:5.0.5 --cluster-enabled yes --cluster-config-file nodes-node-2.conf docker create --name redis-node3 -v /data/redis-data/node3:/data -p 6381:6379 redis:5.0.5 --cluster-enabled yes --cluster-config-file nodes-node-3.conf
          • 第三步:启动容器并创建集群
            • 通过命令docker start $(docker ps -aq) 或者使用docker start redis-node1 redis-node2 redis-node3 来启动3个Redis容器:
              • 第一种:
              • 第二种:
              • 执行完运行命令后检查一下容器的启动情况:
              • 如上提示的是权限问题,我们尝试修改一下权限:
              • chmod -R 777 /data
              • 重新启动成功后如下图所示:
            • 组建集群
              • 查看3个Redis在Docker中分配的ip结点信息: docker inspect redis-node1 | grep IPAddress docker inspect redis-node2 | grep IPAddress docker inspect redis-node3 | grep IPAddress
            • 接下来进入redis-node1这个个容器进行组建集群:
              • docker exec -it redis-node1 /bin/bash
              • redis-cli --cluster create 172.17.0.2:6379 172.17.0.3:6379 172.17.0.4:6379 --cluster-replicas 0
              • ok,此时集群搭建完了,我们接下来测试一下。
            • 测试集群:
              • 使用 redis-cli -c 命令连接到集群结点,然后 set 值(这个值是容器启动的ID号),set 值之后会自动重定向到 0.2 ip地址,然后通过 get 获取一下,获取成功证明集群有效。
          • 第四步:存在的问题和修复方案
            • 按照如上的步骤,虽然集群搭建成功了,但其实还是有点问题的,由于集群节点中的 ip地址 是docker内部分配的,如:172.17.0.2 等,如果使用 redis集群 的项目跟集群不在一台服务器上,那么项目是没法使用集群的,因为是访问不通的。
            • 解决方案:一种解决方案是让Docker使用 host模式 的网络连接类型,Docker在使用host模式下创建的容器是没有自己独立的网络命名空间的,是跟物理机共享一个网络空间,进而可以共享物理机的所有端口与IP,这样就可以让公共网络直接访问容器了,尽管这种方式有安全隐患,但目前来说还没找到其他可行性模式。
              • 就存在的问题我们重新采用 host模式,重新创建一下容器:
                • 1、停止已运行的容器
                  • docker stop redis-node1 redis-node2 redis-node3
                • 2、删除之前创建的容器
                  • docker rm redis-node1 redis-node2 redis-node3
                • 3、重新基于host模式创建
                  • docker create --name redis-node1 --net host -v /data/redis-data/node1:/data redis:5.0.5 --cluster-enabled yes --cluster-config-file nodes-node-1.conf --port 6379 docker create --name redis-node2 --net host -v /data/redis-data/node2:/data redis:5.0.5 --cluster-enabled yes --cluster-config-file nodes-node-2.conf --port 6380 docker create --name redis-node3 --net host -v /data/redis-data/node3:/data redis:5.0.5 --cluster-enabled yes --cluster-config-file nodes-node-3.conf --port 6381 跟之前创建命令不同,一是指定了 --net 网络类型为 host,二是这种情况下就不需要端口映射了,比如 -p 6379:6379,因为此时需要对外共享容器端口服务,所以只需要指定对外暴露的端口 -p 6379、-p 6380 等。
                • 4、启动容器并组建集群
                  • docker start redis-node1 redis-node2 redis-node3
                  • docker exec -it redis-node1 /bin/bash
                  • redis-cli --cluster create 10.211.55.4:6379 10.211.55.4:6380 10.211.55.4:6381 --cluster-replicas 0
                • 5、查看集群信息
                  • redis-cli
                  • cluster nodes
                • 6、测试集群:使用 redis-cli -c 连接到集群上,set一个值,然后从其他节点再获取值查看是否成功:
                  • redis-cli -c
                  • set wxiaowei 123
                  • get wxiaowei
              • 至此,本次基于Docker的Redis集群单副本模式算是搭建好了,文中3个redis都是用的主节点
              相关产品与服务
              云服务器
              云服务器(Cloud Virtual Machine,CVM)提供安全可靠的弹性计算服务。 您可以实时扩展或缩减计算资源,适应变化的业务需求,并只需按实际使用的资源计费。使用 CVM 可以极大降低您的软硬件采购成本,简化 IT 运维工作。
              领券
              问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档