Redis在生产环境中,很少使用单机模式,原因很明显:存在单点故障,无法保证高可用性。所以,在生产环境中可以选择主备模式或者集群模式,这里介绍一下主备模式的自动化部署脚本,后续文章会介绍集群模式的部署。
部署脚本 |
#!/bin/bash
#-------------------------------------------------------------------------------------------#
#---------------------------------------配置信息--------------------------------------------#
#-------------------------------------------------------------------------------------------#
#请准确配置以下信息
#redis所在(绝对)路径
redis_path="/usr/redis-3.2.1"
#保存配置文件的目录 --可不修改
save_file_catalog="config"
#部署模式
#模式1: 将所有主从节点以及sentinel节点部署在同一台机器上
#模式2: 将一个数据节点和一个sentinel节点部署在一台机器上,如master+sentinel1,slave1+sentinel2
#模式3: 将所有节点分开部署
deploy_mode="1"
#主节点配置信息
master_ip="192.168.5.33"
master_port="6379"
#从节点配置信息
redis_slave_num="1"
slave_1_port="6380"
#sentinel配置信息
sentinel_num="2"
sentinel_port_1="26379"
sentinel_port_2="26380"
master_alias="mymaster"
#需要node_fail_votes个sentinel认为该节点下线时,该节点才会被判定为下线
node_fail_votes="1"
#XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX#
#-------------------------------------------------------------------------------------------#
#-------------------------------!!!下方内容请勿修改!!!--------------------------------#
#-------------------------------------------------------------------------------------------#
#创建目录
cd ${redis_path}
if [ -e "${save_file_catalog}" ]
then
rm -rf ${save_file_catalog}
fi
mkdir ${save_file_catalog}
#编译redis
function compileRedis(){
cd ${redis_path}
if [ ! -f "src/redis-sentinel" -o ! -f "src/redis-server" -o ! -f "src/redis-cli" ]
then
echo "The redis may not be compiled. Compile it first! Please wait a moment!"
echo -e "\n\nComplie redis : $(date)\n" >> ${save_file_catalog}/compile.log
make >> ${save_file_catalog}/compile.log 2>&1
make install >> ${save_file_catalog}/compile.log 2>&1
echo -e "Compile success!\n"
fi
}
#修改redis数据节点配置文件
function modifyAndCreateRedisConfigFile(){
echo "Beging to Create and Mmodify redis config file..."
cd ${redis_path}
#将原有redis.conf拷贝(slave_num+1)份
if [ ! -e "redis.conf" ]
then
echo "redis.conf is not exist!"
exit 1
fi
#修改公共配置
lineNum=$(egrep &