本例中将展示创建一个基于docker的redis集群。由于资源有限,该集群由3个master节点组成,没有slave节点。
创建redis节点目录
mkdir -p ~/redis/node1
mkdir -p ~/redis/node1/data
chmod 777 ~/redis/node1/data
创建redis.conf
$ cat redis.conf
#监听端口号,如果所有节点在同一台机器上,每一个节点要用不同的端口
port 6379
#允许的最大连接数
maxclients 1000
#集群模式
cluster-enabled yes
cluster-config-file nodes.conf
cluster-node-timeout 15000
#aof持久化
appendonly yes
appendfsync everysec
#密码
requirepass 123456
#数据文件路径,这里是docker里的路径
dir /usr/local/etc/redis/data
#允许外网ip访问
protected-mode no
把redis配置信息分发到3个节点上
scp -r . node1:/opt/redis
scp -r . node2:/opt/redis
scp -r . node3:/opt/redis
启动所有节点
docker run -v /opt/redis:/usr/local/etc/redis -d --net host redis redis-server /usr/local/etc/redis/redis.conf
命令说明
参数 | 说明 |
-v /opt/redis:/usr/local/etc/redis | 把主机上的redis配置目录挂载到docker下 |
-d | 后台运行 |
--net host | 映射主机的端口,将直接监听主机6379端口 |
redis | docker节点的名称 |
redis-server /usr/local/etc/redis/redis.conf | docker运行命令 |
建立集群
docker run -it redis redis-cli --cluster create ${node1-ip}:6379 ${node2-ip}:6379 ${node3-ip}:6379 --cluster-replicas 0 -a 123456
参数说明
参数 | 说明 |
-it | 使用前台模式运行命令 |
--cluster create ${node1-ip}:6379 ${node2-ip}:6379 ${node3-ip}:6379 | 节点地址 |
--cluster-replicas 0 | 不要slave节点 |
-a 123456 | 节点的密码,要跟redis.conf文件里的密码一样 |
这个命令中途会让你确认slot分布情况,需要打入yes才能继续。
检查
$ redis-cli -c -h 10.0.0.76 -a 123456 cluster nodes
Warning: Using a password with '-a' or '-u' option on the command line interface may not be safe.
858637f2406e498684b1e60fcecf4ad840276dc2 10.0.0.113:6379@16379 master - 0 1640576067894 7 connected 5461-10921
0b02a441444b365b4a9d9d26fe5f8c4fa13d110a 10.0.0.76:6379@16379 myself,master - 0 1640576065000 6 connected 0-5460
b02ea6a3c8b88891a357dfcbc8affea134d3e44d 10.0.0.168:6379@16379 master - 0 1640576067000 8 connected 10922-16383
完成