Docker 自动化脚本部署redis集群

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 $?

你可能感兴趣的:(Docker)