1. 拉取镜像

docker pull redis:5.0.5

  1. 创建redis容器

创建三个 redis 容器:

  • redis-node1: 6379
  • redis-node2:6380
  • redis-node3:6381


  1. 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
  2. docker create --name redis-node2 -v /data/redis-data/node2:/data -p 6380:6379 redis:5.0.5 --cluster-enabled yes --cluster-config-file nodes-node-2.conf
  3. 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
  1. 启动并组建集群
    • 启动容器
      • 首先通过命令 docker start 来启动3个reids容器:
      • docker start redis-node1 redis-node2 redis-node3
      • 执行完运行命令后检查一下容器的启动情况:

image.png

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

image.png

  • 组件集群

    • 查看3个redis在Docker中分配的ip节点信息

      执行「docker inspect redis-node1」得到 redis-node1 ip 信息为:172.17.0.7 
      执行「docker inspect redis-node2」得到 redis-node2 ip 信息为:172.17.0.8 
      执行「docker inspect redis-node3」得到 redis-node3 ip 信息为:172.17.0.9
      

      image.png

    • 拿到ip信息后(每个人的ip信息可能不一样),接下来进入某一个容器进行组件集群: ```

      这里以进入 node1 为例

      docker exec -it redis-node1 /bin/bash

接着执行组建集群命令(请根据自己的ip信息进行拼接)

redis-cli —cluster create 172.17.0.7:6379 172.17.0.8:6379 172.17.0.9:6379 —cluster-replicas 0


![image.png](https://cdn.nlark.com/yuque/0/2020/png/2088655/1607670976907-88a7b3ed-2ee0-4a48-b0d4-5bf8fb1b2c01.png#align=left&display=inline&height=398&margin=%5Bobject%20Object%5D&name=image.png&originHeight=398&originWidth=1179&size=144793&status=done&style=none&width=1179)

   - ok,此时集群搭建完毕,接下来测试一下
4. 测试集群

使用 redis-cli -c 命令连接到集群结点,然后 set 值,set 值之后会自动重定向到 0.2 ip地址,然后通过 get 获取一下,获取成功证明集群有效。<br />![image.png](https://cdn.nlark.com/yuque/0/2020/png/2088655/1607672675360-3b80f4c5-7316-4e07-83eb-fcabcb874274.png#align=left&display=inline&height=115&margin=%5Bobject%20Object%5D&name=image.png&originHeight=115&originWidth=575&size=26788&status=done&style=none&width=575)

<a name="HreAz"></a>
## 存在的问题
按照如上的步骤,虽然集群搭建成功了,但其实还是有点问题的,由于集群结点中的 `ip地址` 是docket内部分配的,如:`172.17.0.7` 等,如果使用 `redis集群` 的项目跟集群不在一台服务器上,那么项目是没法使用集群的,因为是访问不通的<br />![image.png](https://cdn.nlark.com/yuque/0/2020/png/2088655/1607673181700-b9836c7e-15e5-4b4a-935b-be310d1d2a46.png#align=left&display=inline&height=292&margin=%5Bobject%20Object%5D&name=image.png&originHeight=292&originWidth=749&size=16385&status=done&style=none&width=749)<br />一种解决方案是让**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` 等。<br />![image.png](https://cdn.nlark.com/yuque/0/2020/png/2088655/1607674023734-6f946917-5804-4729-8e1c-69c9f2c1579f.png#align=left&display=inline&height=150&margin=%5Bobject%20Object%5D&name=image.png&originHeight=150&originWidth=1363&size=48164&status=done&style=none&width=1363)

4. 启动容器并组建集群

启动命令

docker start redis-node1 redis-node2 redis-node3

进入某一个容器

docker exec -it redis-node1 /bin/bash

组建集群,172.21.135.184为当前物理机的ip地址

redis-cli —cluster create 172.21.135.184:6379 172.21.135.184:6380 172.21.135.184:6381 —cluster-replicas 0

![image.png](https://cdn.nlark.com/yuque/0/2020/png/2088655/1607675975025-d8a602b0-bfaa-4b67-b010-012173b05513.png#align=left&display=inline&height=419&margin=%5Bobject%20Object%5D&name=image.png&originHeight=419&originWidth=1228&size=150336&status=done&style=none&width=1228)

5. 查看集群信息

![image.png](https://cdn.nlark.com/yuque/0/2020/png/2088655/1607676056000-6f6311e9-a500-40eb-922b-b32aed79ec35.png#align=left&display=inline&height=96&margin=%5Bobject%20Object%5D&name=image.png&originHeight=96&originWidth=963&size=37785&status=done&style=none&width=963)

6. 测试集群

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

root@docker-01:/data# redis-cli -c 127.0.0.1:6379> set yctest 123 -> Redirected to slot [8566] located at 172.21.135.184:6380 OK 172.21.135.184:6380> get yetest -> Redirected to slot [11507] located at 172.21.135.184:6381 (nil) 172.21.135.184:6381> get yctest -> Redirected to slot [8566] located at 172.21.135.184:6380 “123” ``` image.png

问题记录:

  1. [ERR] Node 172.21.135.184:6379 is not empty. Either the node already knows other nodes (check with CLUSTER NODES) or contains some key in database 0.

    解决方案:进入redis内,删除conf文件
    image.png

参考网址:https://www.cnblogs.com/niceyoo/p/13011626.html

3主3从参考网址:https://www.cnblogs.com/niceyoo/p/14118146.html