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}\n
protected-mode no\n
cluster-enabled yes\n
cluster-config-file nodes.conf\n
cluster-node-timeout 5000\n
cluster-announce-ip 192.168.2.103\n
cluster-announce-port \${PORT}\n
cluster-announce-bus-port 1\${PORT}\n
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 < ./redis-cluster.tmpl > ./${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脚本 直接执行即可。

你可能感兴趣的:(docker 一键部署redis集群,shell脚本)