搭建 docker 环境下 redis 集群

1. 安装docker

根据不同的系统有不同的安装docker的方法,自行搜索

2. 开放 redis 集群需要用到的端口

根据不同的系统不同的防火墙有不同的开放方法,我的是Ubuntu,用的是 ufw 来开放端口,同时服务器是阿里云的,所以需要在安全组上添加规则,开放 7001-7006 及 17001-17006 这12个端口。

3. 获取 redis 镜像

$ docker pull redis

4. 创建 redis 容器

4.1 创建 redis 的配置文件

在 /home (这个文件夹位置可自行选择,但同时下面的命令需要修改文件夹位置)下新建 redis-cluster 文件夹,然后创建 redis-cluster.tmpl 文件,文件内容如下:

port ${PORT}
protected-mode no
cluster-enabled yes
cluster-config-file nodes.conf
cluster-node-timeout 5000
cluster-announce-ip 192.168.1.157
cluster-announce-port ${PORT}
cluster-announce-bus-port 1${PORT}
appendonly yes

记住你创建该文件夹的位置,同时上述文件的第 6 行cluster-announce-ip 192.168.1.157 最后的 ip 地址192.168.1.157填写自己的外网 ip 地址。

4.2 在/home/redis-cluster下生成conf和data目标,并生成配置信息
$ for port in `seq 7001 7006`; do \
  mkdir -p ./${port}/conf \
  && PORT=${port} envsubst < ./redis-cluster.tmpl > ./${port}/conf/redis.conf \
  && mkdir -p ./${port}/data; \
done

执行该命令要在 /home/redis-cluster 文件夹下。

4.3 创建6个redis容器
$ for port in `seq 7001 7006`; do \
  docker run -d -ti \
  -v /home/redis-cluster/${port}/conf/redis.conf:/usr/local/etc/redis/redis.conf \
  -v /home/redis-cluster/${port}/data:/data \
  --restart always --name redis-${port} --net host \
  --sysctl net.core.somaxconn=1024 redis redis-server /usr/local/etc/redis/redis.conf; \
done

注意:如果你不是在 /home 下新建的 redis-cluster 文件夹,那么需要修改上面命令的路径。

5. 安装 redis 集群

5.1 随意进入一个已运行的 docker 容器
$ docker exec -it redis-7001 bash
5.2 在容器中执行集群命令
/usr/local/bin/redis-cli --cluster create \
192.168.1.157:7001 \
192.168.1.157:7002 \
192.168.1.157:7003 \
192.168.1.157:7004 \
192.168.1.157:7005 \
192.168.1.157:7006 \
--cluster-replicas 1

注意:上面命令的 ip 地址 192.168.1.157,更换为你的 ip 地址。
输入命令中间需要输入yes继续执行。

如果卡在 Waiting for the cluster to join 这里,请注意检查 7001-7006 及 17001-17006 这 12 个端口是否开放及添加安全组规则,检查 ip 地址是否有误。

6. 集群可视化工具

推荐一个免费的工具:AnotherRedisDesktopManager,建议打开工具连接后在命令行界面新增 set key value 看看是否能新增 key。

转载

转载自: https://blog.csdn.net/adolph586/article/details/85340764

外加自己的踩坑及找的可视化工具

两个可能用的上的指令:
停止所有docker容器:docker stop $(docker ps -a -q)
删除所有docker容器:docker rm $(docker ps -a -q)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值