Docker 自动化脚本部署redis集群
#!/bin/bash
#当前路径
cur_dir=$(cd "$(dirname "$0")"; pwd)
cd $cur_dir
#后出现的代码,一旦出现了返回值非零,整个脚本就会立即退出
set -e
#redis镜像名称
IMAGE_NAME=daocloud.io/library/redis:5.0.3
#创建redis容器个数
SUM=6
#容器名称
CONTAINER_NAME=redis_cluster
#容器ip
CONTAINER_IP=" "
#日志文件连接 %T - 24小时制 %X 日期
LOG_FILE=$cur_dir/$0`date +%Y%m%d%H%M%S`.log
echo $LOG_FILE | tee -a $LOG_FILE
#创建redis容器
create_redis(){
for ((i=1;i<=${SUM};i++))
do
#创建redis容器 命令
docker run --name ${CONTAINER_NAME}${i} -p 700${i}:6379 -d ${IMAGE_NAME} redis-server --requirepass '123456' --appendonly yes --protected-mode no --cluster-enabled yes | tee -a $LOG_FILE
done
return 0
}
#获取redis容器的IP
get_container_ip(){
for ((i=1;i<=${SUM};i++))
do
CONTAINER_IP="${CONTAINER_IP} `docker inspect ${CONTAINER_NAME}${i} | grep IPAddress | grep -v null |head -1 | awk -F '"' '{print $4}'`:6379"
done
echo CONTAINER_IP ${CONTAINER_IP} | tee -a $LOG_FILE
return 0
}
#删除redis容器
delete_container(){
docker stop `docker ps | grep ${CONTAINER_NAME} | awk '{print $1}'` > /dev/null 2>&1 | echo
docker rm `docker ps -a | grep ${CONTAINER_NAME} | awk '{print $1}'` > /dev/null 2>&1 | echo
return 0
}
#集群创建
build_redis_cluster(){
docker exec -it ${CONTAINER_NAME}${SUM} /bin/bash -c "echo yes | redis-cli -a 123456 --cluster create ${CONTAINER_IP} --cluster-replicas 1 ;" | tee -a $LOG_FILE
return 0
}
#主函数
main(){
#拉取redis镜像
docker pull $IMAGE_NAME | tee -a $LOG_FILE
#删除redis容器
delete_container
#创建redis容器
create_redis
# 查看 创建 redis 容器
docker ps | grep redis | tee -a $LOG_FILE
#获取redis容器的IP
get_container_ip
#get_container_ip函数返回值 $?
#集群创建
build_redis_cluster
return 0
}
main $@
cd $cur_dir
exit $?