update for 4in1 version

This commit is contained in:
Teddysun 2016-12-05 21:34:24 +09:00
parent 0fee300eb9
commit dab26bb991

View File

@ -6,34 +6,30 @@
# Visit: https://shadowsocks.be/6.html # # Visit: https://shadowsocks.be/6.html #
#=================================================================# #=================================================================#
# name name=(Shadowsocks Shadowsocks-Python ShadowsocksR Shadowsocks-Go Shadowsocks-libev)
name=Shadowsocks
# log path
path=/var/log path=/var/log
# check log path
[[ ! -d ${path} ]] && mkdir -p ${path} [[ ! -d ${path} ]] && mkdir -p ${path}
# log file
log=${path}/shadowsocks-crond.log log=${path}/shadowsocks-crond.log
# shadowsocks-python path(centos)
shadowsocks[0]=/usr/bin/ssserver shadowsocks[0]=/usr/bin/ssserver
# shadowsocks-python path(debian)
shadowsocks[1]=/usr/local/bin/ssserver shadowsocks[1]=/usr/local/bin/ssserver
# shadowsocks-go path
shadowsocks[2]=/usr/bin/shadowsocks-server shadowsocks[2]=/usr/bin/shadowsocks-server
# shadowsocks-libev path
shadowsocks[3]=/usr/local/bin/ss-server shadowsocks[3]=/usr/local/bin/ss-server
# shadowsocksR path
shadowsocks[4]=/usr/local/shadowsocks/server.py shadowsocks[4]=/usr/local/shadowsocks/server.py
# default pid value
shadowsocks_init[0]=/etc/init.d/shadowsocks
shadowsocks_init[1]=/etc/init.d/shadowsocks-python
shadowsocks_init[2]=/etc/init.d/shadowsocks-r
shadowsocks_init[3]=/etc/init.d/shadowsocks-go
shadowsocks_init[4]=/etc/init.d/shadowsocks-libev
i=0
for init in ${shadowsocks_init[@]}; do
pid="" pid=""
if [ -f ${init} ]; then
[ ! -f /etc/init.d/shadowsocks ] && echo "`date +"%Y-%m-%d %H:%M:%S"` /etc/init.d/shadowsocks is not existed" >> ${log} && exit ${init} status &>/dev/null
# check Shadowsocks status
/etc/init.d/shadowsocks status &>/dev/null
if [ $? -eq 0 ]; then if [ $? -eq 0 ]; then
for bin in ${shadowsocks[*]} for bin in ${shadowsocks[@]}; do
do
pid=`ps -ef | grep -v grep | grep -i "${bin}" | awk '{print $2}'` pid=`ps -ef | grep -v grep | grep -i "${bin}" | awk '{print $2}'`
if [ ! -z ${pid} ]; then if [ ! -z ${pid} ]; then
break break
@ -41,16 +37,19 @@ if [ $? -eq 0 ]; then
done done
fi fi
# check status & auto start
if [ -z ${pid} ]; then if [ -z ${pid} ]; then
echo "`date +"%Y-%m-%d %H:%M:%S"` $name is not running" >> ${log} echo "`date +"%Y-%m-%d %H:%M:%S"` ${name[$i]} is not running" >> ${log}
echo "`date +"%Y-%m-%d %H:%M:%S"` Starting $name" >> ${log} echo "`date +"%Y-%m-%d %H:%M:%S"` Starting ${name[$i]}" >> ${log}
/etc/init.d/shadowsocks start &>/dev/null ${init} start &>/dev/null
if [ $? -eq 0 ]; then if [ $? -eq 0 ]; then
echo "`date +"%Y-%m-%d %H:%M:%S"` $name start success" >> ${log} echo "`date +"%Y-%m-%d %H:%M:%S"` ${name[$i]} start success" >> ${log}
else else
echo "`date +"%Y-%m-%d %H:%M:%S"` $name start failed" >> ${log} echo "`date +"%Y-%m-%d %H:%M:%S"` ${name[$i]} start failed" >> ${log}
fi fi
else else
echo "`date +"%Y-%m-%d %H:%M:%S"` $name is running with pid $pid" >> ${log} echo "`date +"%Y-%m-%d %H:%M:%S"` ${name[$i]} is running with pid $pid" >> ${log}
fi fi
fi
((i++))
done