基于docker搭建的redis集群

  1. 拉取redis镜像

    docker  pull  redis:5.0.5
    
  2. 创建redis容器

    创建三个redis容器:

    • redis-node1:6379
    • redis-node2:6380
    • redis-node2:6381
    docker create --name redis-node1 -v /Users/gtshawn/Documents/mydata/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 	/Users/gtshawn/Documents/mydata/redis-data/node2:/data -p 6380:6379 redis:5.0.5 --cluster-enabled yes --cluster-config-file nodes-node-2.conf
    
    docker create --name redis-node3 -v /Users/gtshawn/Documents/mydata/redis-data/node3:/data -p 6381:6379 redis:5.0.5 --cluster-enabled yes --cluster-config-file nodes-node-3.conf
    
  3. 启动并组建集群
    启动容器
    通过命令docker start 来启动3个redis容器:在这里插入图片描述
    组建集群
    查看3个redis在docker中分配的ip节点信息:

    执行「docker inspect redis-node1」得到 redis-node1 ip 信息为:	172.17.0.4 
    执行「docker inspect redis-node2」得到 redis-node2 ip 信息为:172.17.0.3 
    执行「docker inspect redis-node3」得到 redis-node3 ip 信息为:172.17.0.2
    

在这里插入图片描述
拿到ip信息后(每一个的IP信息可能不一样),接下来进入某一个容器中组建集群:

#这里以进入 node1 为例
docker exec -it redis-node1 /bin/bash

#接着执行组建集群命令(请根据自己的ip信息进行拼接)
redis-cli --cluster create 172.17.0.2:6379  172.17.0.3:6379  172.17.0.4:6379 --cluster-replicas 0

在这里插入图片描述
集群搭建完成
使用 redis-cli -c 命令连接到集群结点,然后 set 值,set 值之后会自动重定向到 0.2 ip地址,然后通过 get 获取一下,获取成功证明集群有效。

  1. 存在的问题
    按照如上的步骤,虽然集群搭建成功了,但其实还是有点问题的,由于集群结点中的 ip地址 是docket内部分配的,如: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
#清空上面创建的配置文件
rm -rf /Users/gtshawn/Documents/mydata/redis-data/node*

(3)重新基于host模式创建

docker create --name redis-node1 --net host -v /Users/gtshawn/Documents/mydata/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 /Users/gtshawn/Documents/mydata/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 /Users/gtshawn/Documents/mydata/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 127.0.0.1:6379  127.0.0.1:6380  127.0.0.1:6381 --cluster-replicas 0

在这里插入图片描述
查看集群信息

redis-cli

cluster nodes


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

root@docker-desktop:/data# redis-cli -c
127.0.0.1:6379> set shawn 123
-> Redirected to slot [8120] located at 127.0.0.1:6380
OK
127.0.0.1:6380> get shawn
"123"

至此,本次基于Docker的Redis集群单副本模式算是搭建好了

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值