没有合适的资源?快使用搜索试试~ 我知道了~
docker 一键部署redis集群,shell脚本
11 下载量 160 浏览量
2021-01-20
12:21:47
上传
评论
收藏 37KB PDF 举报
温馨提示
试读
1页
如下图所示docker 容器下。redis一键集群。 为了新手小伙伴发愁集群创建难,特意写了一个shell脚本。自己技术也很菜,但是我坚信也会有跟我一样菜的小伙伴。。。。哈哈哈 不多说直接上脚本 希望有大神更加优化一下,优化后的版本可以分享下。哇 等着你大神,一起交流技术。 #!/bin/bash docker rm -f `docker ps --filter name=.*redis-700.* -aq` echo 1.请输入您要部署的目录位置 gml= while : do read path if [[ $path =~ ^([\/]{1}[a-zA-Z]
资源详情
资源评论
资源推荐
docker 一键部署一键部署redis集群,集群,shell脚本脚本
如下图所示docker 容器下。redis一键集群。
为了新手小伙伴发愁集群创建难,特意写了一个shell脚本。自己技术也很菜,但是我坚信也会有跟我一样菜的小伙伴。。。
。哈哈哈
不多说直接上脚本
希望有大神更加优化一下,优化后的版本可以分享下。哇 等着你大神,一起交流技术。
#!/bin/bash
docker rm -f `docker ps --filter name=.*redis-700.* -aq`
echo "1.请输入您要部署的目录位置"
gml=""
while :
do
read path
if [[ "$path" =~ ^([\/]{1}[a-zA-Z]{1,9}){1,5}$ ]];then
gml=$path
break
else
echo "$path不符合linux路径标准"
echo "输入一个合法的根目录如《/path/path1...》"
fi
done
rm -rf $path/redis
mkdir $path
cd $gml
echo "2.正在创建redis目录"
mkdir redis
cd redis
docker pull redis:5.0.4
echo "3.正在创建redis集群模板"
touch redis-cluster.tmpl
echo -e "port \${PORT}
protected-mode no
cluster-enabled yes
cluster-config-file nodes.conf
cluster-node-timeout 5000
cluster-announce-ip 192.168.2.103\n
cluster-announce-port \${PORT}
cluster-announce-bus-port 1\${PORT}
appendonly yes">>redis-cluster.tmpl
docker network create redis-net
echo "4.完成模板创建"
echo "5.正在创建redis配置"
for port in `seq 7000 7005`
do
mkdir -p ./${port}/conf && PORT=${port} envsubst ./${port}/conf/redis.conf && mkdir -p ./${port}/data
done
echo "6.redis配置创建完成"
ips=""
for port in `seq 7000 7005`
do
docker run --privileged=true -m 200m -d -p ${port}:${port} -p 1${port}:1${port} -v
/${gml}/redis/${port}/conf/redis.conf:/usr/local/etc/redis/redis.conf -v /${gml}/redis/${port}/data:/d
ata --restart always --name redis-${port} --net redis-net --sysctl net.core.somaxconn=1024 redis:5.0.4 redis-server
/usr/local/etc/redis/redis.conf
echo "7.正在创建redis-$port 容器"
ips="$ips`docker inspect redis-${port} --format '{{ (index .NetworkSettings.Networks "redis-net").IPAddress }}'`:${port} "
done
echo "所有容器中创建完成"
docker exec -it redis-7000 bash -c "echo yes | redis-cli --cluster create $ips --cluster-replicas 1 && exit"
echo "集群启动成功!!!"
把内容拷贝出来放在shell结尾可执行 linux脚本 直接执行即可。
作者:哗啦个哗
weixin_38685538
- 粉丝: 5
- 资源: 1025
上传资源 快速赚钱
- 我的内容管理 展开
- 我的资源 快来上传第一个资源
- 我的收益 登录查看自己的收益
- 我的积分 登录查看自己的积分
- 我的C币 登录后查看C币余额
- 我的收藏
- 我的下载
- 下载帮助
安全验证
文档复制为VIP权益,开通VIP直接复制
信息提交成功
评论0