redis-集羣建立腳本

以前建好了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
相關文章
相關標籤/搜索