redis 测试集群搭建

最近因为服务需要,在测试环境搭建了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

参考: 如何搭建redis集群 — redis-cluster

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值