refactor(server): 重构 LogicServer 监控和启动脚本
- 新增 LogicServer/daemon.sh 脚本,专门用于监控和重启 LogicServer - 修改 LogicServer/run.sh,添加启动日志输出 - 从 daemon.sh 中移除 LogicServer 相关的监控逻辑 - 在 run.sh 中注释掉 LogicServer 启动代码,统一启动逻辑
This commit is contained in:
33
daemon.sh
33
daemon.sh
@@ -30,39 +30,6 @@ while true; do
|
||||
echo "[$datetime] $path/Gateway/gateway$dm $path/Gateway/GateWay.txt"
|
||||
fi
|
||||
|
||||
# check LogicServer
|
||||
|
||||
ret=`ps x |grep $path/LogicServer/logicserver$dm|grep -v grep|grep -v "/bin/bash"|wc -l`
|
||||
if [ $ret == 0 ]; then
|
||||
$path/LogicServer/logicserver$dm $path/LogicServer/LogicServerLinux.txt > /dev/null &
|
||||
echo "[$datetime] $path/LogicServer/logicserver$dm $path/LogicServer/LogicServerLinux.txt"
|
||||
else
|
||||
pid=`top -bn 1 -i -c |awk '{ if (NR > 6) print }' |awk '{ if ($9 > 99) print $1}' |head -n1`
|
||||
if [[ -n $pid ]]; then
|
||||
echo "[$datetime] 开始结束服务器: $curdoc LogicServer (pid=$pid)"
|
||||
kill -15 $pid
|
||||
NUM=2
|
||||
while true; do
|
||||
datetime=`date "+%Y-%m-%d.%H:%M:%S"`
|
||||
proc=`ps aux |grep $path|grep logicserver|grep -v grep|grep "\<$curdoc\>"|grep -v "/bin/bash"|wc -l`
|
||||
if [ $proc == 0 ]; then
|
||||
break
|
||||
fi
|
||||
if [ $NUM -lt 0 ]; then
|
||||
echo "[$datetime] 游戏服务 $curdoc LogicServer 强制结束"
|
||||
kill -9 $pid
|
||||
$path/LogicServer/logicserver$dm $path/LogicServer/LogicServerLinux.txt > /dev/null &
|
||||
echo "[$datetime] 游戏服务 $curdoc LogicServer 启动完毕"
|
||||
echo "--------------------------------------------------"
|
||||
break
|
||||
fi
|
||||
echo "[$datetime] 游戏服务 $curdoc LogicServer 结束中..."
|
||||
sleep 1
|
||||
let NUM--
|
||||
done
|
||||
fi
|
||||
fi
|
||||
|
||||
#ret=`ps x |grep $path/LogicServer/robot$dm|grep -v grep|grep -v "/bin/bash"|wc -l`
|
||||
#if [ $ret == 0 ]; then
|
||||
#$path/LogicServer && ./robot$dm
|
||||
|
||||
Reference in New Issue
Block a user