以前建好了redis集羣, 但沒有找到集羣重啓的機制, 停電2次, 從新建立太麻煩, 因而寫了個腳本輔助啓動html
redis的建立過程能夠看: node
http://www.cnblogs.com/wenbronk/p/6864390.html http://www.cnblogs.com/wenbronk/p/6865914.html
而後, 直接放在父目錄下就能夠了redis
[wenbronk@localhost redis1]$ cat redis-cluster.sh #!/bin/bash # create by wenbronk at 2017/7/17 # redis集羣管理腳本 PORTNUM=6 PASS_WD=bd86d2ab-08e5-4ae0-87ce-06cc021336d0 REDIS_HOME=/opt/wenbronk_soft/redis/redis1 HOST1=192.168.50.202 PORT1=7000 PORT2=7001 PORT3=7002 PORT4=7003 PORT5=7004 PORT6=7005 HOSTS=($HOST1 $HOST1 $HOST1 $HOST1 $HOST1 $HOST1) PORTS=($PORT1 $PORT2 $PORT3 $PORT4 $PORT5 $PORT6) BASE_DIR=(bin bin1 bin2 bin3 bin4 bin5) declare -A HOST_GROUP # clean if [ "$1" == "clean" ] then for direct in $REDIS_HOME/* do if [ -d "$direct" ] then echo $direct rm -rf $direct/dump* rm -rf $direct/nodes* rm -rf $direct/appendonly* sed -i '1{:a;N;'$n'!b a};$d;N;P;D' $direct/redis.conf fi done exit 0 fi #create if [ "$1" == "create" ] then for direct in $REDIS_HOME/* do if [ -d "$direct" ] then $direct/redis-server $direct/redis.conf PORTNUM=$((PORTNUM-1)) HOST_GROUP[$PORTNUM]=${HOSTS[$PORTNUM]}:${PORTS[$PORTNUM]} fi done $REDIS_HOME/bin/redis-trib.rb create --replicas 1 ${HOST_GROUP[*]} exit 0 fi #auth if [ "$1" == "auth" ] then for direct in $REDIS_HOME/* do if [ -d "$direct" ];then PORTNUM=$PORTNUM-1 $direct/redis-cli -c -h ${HOSTS[$PORTNUM]} -p ${PORTS[$PORTNUM]} config set masterauth $PASS_WD $direct/redis-cli -c -a $PASS_WD -h ${HOSTS[$PORTNUM]} -p ${PORTS[$PORTNUM]} config set requirepass $PASS_WD $direct/redis-cli -c -a $PASS_WD -h ${HOSTS[$PORTNUM]} -p ${PORTS[$PORTNUM]} auth $PASS_WD $direct/redis-cli -c -a $PASS_WD -h ${HOSTS[$PORTNUM]} -p ${PORTS[$PORTNUM]} config rewrite # $direct/redis-cli -c -h ${HOSTS[$PORTNUM]} -p ${PORTS[$PORTNUM]} exit fi done exit 0 fi #stop if [ "$1" == "stop" ] then pkill -9 redis fi exit 0 #help if [ "$1" == "help" ] then echo "stop|clean|create|auth" fi exit 0
因爲沒有找到和shell交互的方式, 建立的時候須要輸入一個yes, 因此吧集羣建立和密碼設置分開了shell
執行時, stop->clean->create->auth 便可實現bash
而後集羣的統一啓動腳本app
開始想用spawn, 但找了半天沒找到怎麼循環使用, 因此須要在每一個機器俠有個start-this.sh用於本機的redis管理ssh
#!/bin/bash # create by wenbronk at 2017/7/17 # redis 集羣管理腳本 PORTNUM=6 PASS_WD=bd86d2ab-08e5-4ae0-87ce-06cc021336d0 REDIS_HOME=/opt/redis HOST1=redis-130 HOST2=redis-131 HOST3=redis-132 PORT1=20327 PORT2=20329 HOSTS=($HOST1 $HOST1 $HOST2 $HOST2 $HOST3 $HOST3) PORTS=($PORT1 $PORT2 $PORT1 $PORT2 $PORT1 $PORT2) BASEDIR=(bin-20327 bin-20329) declare -A HOSTGROUP case "$1" in #clean clean) for (( i=0; i<${#HOSTS[@]}; i=i+2)) do ssh root@${HOSTS[$i]} "sh $REDIS_HOME/start-this.sh clean" done exit 0 ;; #create create) for (( i=0; i<${#HOSTS[@]}; i=i+1)) do ssh root@${HOSTS[$i]} "sh $REDIS_HOME/start-this.sh create" HOSTGROUP[$i]=${HOSTS[$i]}:${PORTS[$i]} i=$((i+1)) HOSTGROUP[$i]=${HOSTS[$i]}:${PORTS[$i]} done $REDIS_HOME/bin/redis-trib.rb create --replicas 1 ${HOSTGROUP[*]} ;; #auth auth) for (( i=0; i<${#HOSTS[@]}; i=i+1)) do echo connect to ${HOST[$i]} at ${PORTS[$i]} and change passwd $direct/redis-cli -c -h ${HOSTS[$i]} -p ${PORTS[$i]} config set masterauth $PASS_WD $direct/redis-cli -c -a $PASS_WD -h ${HOSTS[$i]} -p ${PORTS[$i]} config set requirepass $PASS_WD $direct/redis-cli -c -a $PASS_WD -h ${HOSTS[$i]} -p ${PORTS[$i]} auth $PASS_WD $direct/redis-cli -c -a $PASS_WD -h ${HOSTS[$i]} -p ${PORTS[$i]} config rewrite done exit 0 ;; #other *) echo "unsupport params!! please input stop|clean|create|auth as params_one" exit 1 esac
start-this.shui
#!/bin/bash # create by wenbronk at 2017/7/19 # redis cluster clean & create REDIS_HOME=/opt/redis HOSTIP=redis-130 case "$1" in clean) echo "connect to $HOSTIP" for direct in $REDIS_HOME/* do if [ -d "$direct" ];then rm -rf $direct/dump* echo "rm $direct/dump*" rm -rf $direct/nodes* echo "rm $direct/nodes*" rm -rf $direct/appendonly* echo "rm $direct/appendonly*" sed -i '1{:a;N;'$n'!b a};$d;N;P;D' $direct/redis.conf echo "sed last 2 line at $direct/redis.conf" fi done echo "logout from $HOSTIP" exit 0 ;; start) echo "connect to $HOSTSIP" for direct in $REDIS_HOME/* do if [ -d "$direct" ];then echo "start redis $HOSTIP" $REDIS_HOME/redis-server.sh $REDIS_HOME/redis.conf fi done echo "logout from $HOSTSIP" exit 0 ;; esac
ps: 本腳本只用於redis集羣的統一啓動, 不用於搭建, 須要有預先搭建好的環境, 關於redis集羣的搭建, 能夠參考另外一個博客: this
http://www.cnblogs.com/wenbronk/p/6864390.html