Docker上实现Redis集群搭建
环境:docker + ( redis:5.0.5 * 3 )
1、拉取镜像
2、创建redis容器
创建三个 redis 容器:
redis-node1:6379
redis-node2:6380
redis-node3:6381
3、启动并组建集群启动容器
首先通过命令docker start
来启动3个redis容器:
执行完运行命令后检查一下容器的启动情况:
如果出现上图情况,exited (1) 3 seconds ago
,可以通过 docker logs
查看:
如上提示的是权限问题,我们尝试修改一下权限:
启动成功后如下图所示:
组建集群
查看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信息可能不一样),接下来进入某一个容器进行组建集群:
ok,此时集群搭建完了,我们接下来测试一下。
测试集群
使用 redis-cli -c
命令连接到集群结点,然后 set 值,set 值之后会自动重定向到 0.2 ip地址,然后通过 get 获取一下,获取成功证明集群有效。
4、存在的问题
按照如上的步骤,虽然集群搭建成功了,但其实还是有点问题的,由于集群结点中的 ip地址
是docket内部分配的,如:172.17.0.2
等,如果使用 redis集群
的项目跟集群不在一台服务器上,那么项目是没法使用集群的,因为是访问不通的。
一种解决方案是让docker使用 host模式
的网络连接类型,docker在使用host模式
下创建的容器是没有自己独立的网络命名空间的,是跟物理机共享一个网络空间,进而可以共享物理机的所有端口与ip,这样就可以让公共网络直接访问容器了,尽管这种方式有安全隐患,但目前来说还没找到其他可行性模式。
就存在的问题我们重新采用 host模式
,重新创建一下容器:
1、停止已运行的容器
2、删除之前创建的容器
3、重新基于host模式创建
跟之前创建命令不同,一是指定了 --net
网络类型为 host
,二是这种情况下就不需要端口映射了,比如 -p 6379:6379
,因为此时需要对外共享容器端口服务,所以只需要指定对外暴露的端口 -p 6379
、-p 6380
等。
4、启动容器并组建集群
5、查看集群信息
6、测试集群
使用 redis-cli -c
连接到集群上,set
一个值,然后从其他节点再获取值查看是否成功:
至此,本次基于docker的redis集群单副本模式
算是搭建好了,文中3个redis都是用的主节点,关于多副本、主从架构高可用在后文补充。
你们要的主从集群:
到此这篇关于docker上实现redis集群搭建 的文章就介绍到这了,更多相关docker redis集群搭建内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!