Linux下Redis啟動/關閉/重啟服務指令碼

來源:互聯網
上載者:User

標籤:

指令碼功能:

       實現redis單機多執行個體情況下的正常啟動、關閉、重啟單個redis執行個體。完成系統標準服務的以下常用功能:  start|stop|status|restart

      註:redis程式碼屏蔽了HUP訊號,不支援線上重載設定檔,故去掉reload功能。

             本指令碼最佳化了redis停止和重啟邏輯,解決原redis指令碼關閉時會造成資料丟失問題。

 

指令碼名稱:

        redis           #在多執行個體裡可以按執行個體連接埠,如:redis-6001命名,以區分不同執行個體

 

指令碼用法:

1.在/etc/rc.d/init.d/目錄下建立redis檔案,將指令碼內容拷貝進去

2.  chkconfig --add redis   #註冊服務

3. chkconfig --level 345 redis on  #指定服務在3、4、5層級運行

4.本人redis程式安裝在/usr/local/redis目錄下,配置為/usr/local/redis/bin/redis.conf,如安裝在其他目錄,請自行修改

指令碼參數:

        redis -p [port]  [start|stop|status|restart]

              參數說明:

          -p [port] : 指定redis執行個體的連接埠,用於多執行個體的伺服器

         start:啟動指定連接埠的Redis服務

         stop:停止指定連接埠的Redis服務

        status:進程狀態

       restart:先關閉Redis服務,再啟動Redis服務

      註:不指定連接埠時,指令碼預設指定啟動6379連接埠的redis

用法執行個體:

    service redis -p 6381 start  #啟動6381連接埠執行個體的redis

   /etc/init.d/redis  start  #預設啟動6379連接埠執行個體的redis

指令碼內容:

#!/bin/bash
#chkconfig: 2345 55 25
#description: Starts,stops and restart the redis-server
#Ver:1.1  
#Write by ND chengh(200808)
#usage: ./script_name -p [port] {start|stop|status|restart}

# Source function library.
. /etc/rc.d/init.d/functions

# Source networking configuration.
. /etc/sysconfig/network

# Check networking is up.
[ "$NETWORKING" = "no" ] && exit 0

RETVAL=0
REDIS_PORT=6379
PID=

if [ "$1" = "-p" ]; then
    REDIS_PORT=$2
    shift 2
fi

REDIS_DIR="/usr/local/redis"
REDIS="${REDIS_DIR}/bin/redis-server"
PROG=$(basename $REDIS)

CONF="${REDIS_DIR}/bin/redis-${REDIS_PORT}.conf"

if [ ! -f $CONF ]; then
   if [ -f "${REDIS_DIR}/bin/redis.conf" ];then
      CONF="${REDIS_DIR}/bin/redis.conf"
   else
      echo -n $"$CONF not exist.";warning;echo
      exit 1
   fi
fi

PID_FILE=`grep "pidfile" ${CONF}|cut -d ‘ ‘ -f2`
PID_FILE=${PID_FILE:=/var/run/redis.pid}
LOCKFILE="/var/lock/subsys/redis-${REDIS_PORT}"

if [ ! -x $REDIS ]; then
    echo -n $"$REDIS not exist.";warning;echo
    exit 0
fi


start() {

    echo -n $"Starting $PROG: "
    $REDIS $CONF
    RETVAL=$?
    if [ $RETVAL -eq 0 ]; then
        success;echo;touch $LOCKFILE
    else
        failure;echo
    fi
    return $RETVAL

}

stop() {

    echo -n $"Stopping $PROG: "

    if [ -f $PID_FILE ] ;then
       read PID <  "$PID_FILE" 
    else 
       failure;echo;
       echo -n $"$PID_FILE not found.";failure;echo
       return 1;
    fi

    if checkpid $PID; then
     kill -TERM $PID >/dev/null 2>&1
        RETVAL=$?
        if [ $RETVAL -eq 0 ] ;then
                success;echo 
                echo -n "Waiting for Redis to shutdown .."
         while checkpid $PID;do
                 echo -n "."
                 sleep 1;
                done
                success;echo;rm -f $LOCKFILE
        else 
                failure;echo
        fi
    else
        echo -n $"Redis is dead and $PID_FILE exists.";failure;echo
        RETVAL=7
    fi    
    return $RETVAL

}

restart() {
    stop
    start
}

rhstatus() {
    status -p ${PID_FILE} $PROG
}

hid_status() {
    rhstatus >/dev/null 2>&1
}

case "$1" in
    start)
        hid_status && exit 0
        start
        ;;
    stop)
        rhstatus || exit 0
        stop
        ;;
    restart)
        restart
        ;;
    status)
        rhstatus
        RETVAL=$?
        ;;
    *)
        echo $"Usage: $0 -p [port] {start|stop|status|restart}"
        RETVAL=1
esac

exit $RETVAL



轉載自:http://blog.csdn.net/chhxo/article/details/8673020

Linux下Redis啟動/關閉/重啟服務指令碼

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.