From c8419c2fe8ce4ea77740c44c9a8ea2358df842e9 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=E6=98=9F=E5=85=89-k?= <36470587+kxgx@users.noreply.github.com> Date: Mon, 13 Jan 2025 18:45:30 +0000 Subject: [PATCH] =?UTF-8?q?=E6=9B=B4=E6=96=B0=20start.sh?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- bin/start.sh | 26 +++++++++++++++++++++----- 1 file changed, 21 insertions(+), 5 deletions(-) diff --git a/bin/start.sh b/bin/start.sh index 6322d60..029486f 100755 --- a/bin/start.sh +++ b/bin/start.sh @@ -1,18 +1,29 @@ #!/bin/bash +# 脚本文件名 f_name=main.py +# 获取脚本所在目录的路径 dir=$( cd "$( dirname "${BASH_SOURCE[0]}" )" && pwd ) +# 日志目录,假设是脚本所在目录的上一级目录 logdir=${dir%/*} +# screen会话名称 screen_name="main_screen" +# 最大重试次数 +max_retries=180 +# 重试间隔时间(秒) +retry_interval=5 +# 重试计数器 +retry_count=0 # 函数用于启动Python脚本 start_script() { # 创建一个新的screen会话并运行Python脚本 - screen -dmS $screen_name /usr/bin/python3 -u $dir/$f_name 2>&1 + # 输出重定向到日志文件 + screen -dmS $screen_name /usr/bin/python3 -u $dir/$f_name > $logdir/log/info.log 2>&1 } # 主循环 -while true; do +while [ $retry_count -lt $max_retries ]; do # 检查是否有与指定screen_name相关的screen会话正在运行 existing_sessions=$(screen -ls | grep -w $screen_name) @@ -28,8 +39,13 @@ while true; do start_script # 等待一段时间,检查脚本是否还在运行 - sleep 180 + sleep $retry_interval if ! screen -list | grep -q $screen_name; then - echo "Script stopped unexpectedly. Restarting..." + echo "脚本意外停止。正在重启..." + ((retry_count++)) # 增加重试计数 + else + retry_count=0 # 如果脚本还在运行,重置重试计数 fi -done \ No newline at end of file +done + +echo "达到最大重试次数。退出..." \ No newline at end of file