最近因为服务需要,在测试环境搭建了redis cluster 模式的测试集群。
坑一
redis.conf 配置文件中的 port 配置为 0.0.0.0 , 而不是127.0.0.1 , 二者区别在于:
- IPV4中,0.0.0.0地址被用于表示一个无效的,未知的或者不可用的目标。
- 在服务器中,0.0.0.0指的是本机上的所有IPV4地址,如果一个主机有两个IP地址,192.168.1.1 和 10.1.2.1,并且该主机上的一个服务监听的地址是0.0.0.0,那么通过两个ip地址都能够访问该服务。
- 在路由中,0.0.0.0表示的是默认路由,即当路由表中没有找到完全匹配的路由的时候所对应的路由。
127.0.0.1 是一个环回地址。并不表示“本机”。0.0.0.0才是真正表示“本网络中的本机”。
在实际应用中,一般我们在服务端绑定端口的时候可以选择绑定到0.0.0.0,这样我的服务访问方就可以通过我的多个ip地址访问我的服务。
参考脚本
创建目录与配置:
在redis.conf 中
配置port 为如下:
port ${PORT}
pidfile /var/run/redis_${PORT}.pid
envsubst 命令自动对 redis.conf 中的 ${PORT} 部分进行动态替换。
for port in `seq 6000 6005`; do
mkdir -p ./redis-conf/${port} && PORT=${port} envsubst < ./redis.conf > ./redis-conf/${port}/redis.conf && mkdir -p ./redis-conf/${port}/data;
done
启动
echo "starting redis-cluster"
oldNodesNum=`ps -ef | grep redis | grep -v grep | wc -l`
if [ "${oldNodesNum}" -ne 0 ]
then
`ps aux | grep redis | grep cluster | grep -v grep | awk '{print $2}' | xargs kill -9`
fi
for port in `seq 6000 6005`; do
/Users/liquanbang/redis-cluster2/redis-server/src/redis-server /Users/liquanbang/redis-cluster2/redis-conf/${port}/redis.conf
done
# /Users/liquanbang/redis-cluster2/redis-server/src/redis-cli --cluster create 127.0.0.1:6001 127.0.0.1:6002 127.0.0.1:6003 127.0.0.1:6004 127.0.0.1:6005 127.0.0.1:6000 --cluster-replicas 1
nodesNum=`ps -ef | grep redis | grep -v grep | wc -l`
if [ "${nodesNum}" -lt 6 ]
then
`ps aux | grep redis | grep cluster | grep -v grep | awk '{print $2}' | xargs kill -9`
echo "started failed"
else
echo "started success"
fi
停止
#/bin/bash
ps aux | grep redis | grep cluster | grep -v grep | awk '{print $2}' | xargs kill -9
activeNodesNum=`ps -ef | grep redis | grep cluster | grep -v grep | wc -l`
if [ "${activeNodesNum}" -ne 0 ]
then
echo "shutdown failed"
else
echo "shutdown success"
fi