-
Notifications
You must be signed in to change notification settings - Fork 1
Expand file tree
/
Copy pathtaskflowPro.sh
More file actions
executable file
·213 lines (182 loc) · 8.1 KB
/
taskflowPro.sh
File metadata and controls
executable file
·213 lines (182 loc) · 8.1 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
#!/bin/bash
#======= 用户可配置变量 =======
# 配置你的conda环境名称
CONDA_ENV="pytorch24"
# 配置你的主脚本名称(如果不使用shell命令)
SCRIPT_NAME="MultiTaskFlow.py" # 没有 taskflow 的时候使用
# 配置PID文件名称
PID_FILE_NAME="multitaskflow.pid"
# 任务配置文件路径(完整路径,例如:/path/to/your/TaskFlow.yaml)
TASK_CONFIG="/userhome/lhf/Codes/WorkSpace/VisDrone/TaskFlow.yaml"
# 配置等待时间(秒)
WAIT_TIME=3
#============================
# 定义颜色输出
GREEN='\033[0;32m'
RED='\033[0;31m'
YELLOW='\033[0;33m'
BLUE='\033[0;34m'
NC='\033[0m' # 无颜色
# 检查命令行参数
if [ $# -lt 1 ]; then
echo -e "${RED}错误: 缺少操作参数${NC}"
echo -e "用法: $0 [start|stop] [配置文件路径]"
echo -e "示例: $0 start"
echo -e " $0 stop"
echo -e " $0 start /path/to/your/CustomTask.yaml"
exit 1
fi
ACTION=$1
shift # 移除第一个参数
# 检查是否有自定义配置文件路径
if [ $# -gt 0 ]; then
TASK_CONFIG="$1"
fi
## 获取当前脚本所在目录
current_dir=$(cd $(dirname $0); pwd)
echo -e "${BLUE}当前脚本目录: ${current_dir}${NC}"
## 检查配置文件并设置工作目录
if [ -z "$TASK_CONFIG" ]; then
echo -e "${RED}错误: 未指定任务配置文件路径${NC}"
exit 1
fi
if [ ! -f "$TASK_CONFIG" ]; then
echo -e "${RED}错误: 配置文件 '$TASK_CONFIG' 不存在${NC}"
exit 1
fi
# 提取配置文件所在目录作为工作目录
target_dir=$(dirname "$TASK_CONFIG")
config_file=$(basename "$TASK_CONFIG")
echo -e "${BLUE}任务配置文件: ${TASK_CONFIG}${NC}"
echo -e "${BLUE}工作目录: ${target_dir}${NC}"
## 日志目录和PID文件路径
log_dir="${target_dir}/logs"
pid_file="${log_dir}/${PID_FILE_NAME}"
## 根据操作执行不同功能
case $ACTION in
start)
# 启动任务函数
## 获取当前日期
current_date=$(date +%Y%m%d_%H%M%S)
echo -e "${BLUE}运行日期: ${current_date}${NC}"
## 检查日志目录
if [ ! -d "$log_dir" ]; then
mkdir -p "$log_dir"
echo -e "${BLUE}创建日志目录: ${log_dir}${NC}"
fi
## 日志文件名
log_file="${log_dir}/TaskFlow_full_${current_date}.log"
echo -e "${BLUE}日志将保存至: ${log_file}${NC}"
## 激活conda环境
echo -e "${BLUE}正在激活conda环境 '${CONDA_ENV}'...${NC}"
source $(conda info --base)/etc/profile.d/conda.sh
conda activate $CONDA_ENV || { echo -e "${YELLOW}conda环境 '${CONDA_ENV}' 激活失败,尝试继续执行...${NC}"; }
# 检查是否存在taskflow命令
if command -v taskflow &> /dev/null; then
echo -e "${GREEN}发现taskflow命令,使用shell命令运行${NC}"
CMD="cd ${target_dir} && taskflow ${config_file}"
else
# 检查脚本是否存在
if [ ! -f "${target_dir}/${SCRIPT_NAME}" ]; then
echo -e "${YELLOW}警告: ${target_dir}/${SCRIPT_NAME} 文件不存在!${NC}"
exit 1
fi
echo -e "${GREEN}使用Python脚本运行${NC}"
CMD="cd ${target_dir} && python ${SCRIPT_NAME} ${config_file}"
fi
## 运行脚本并保存PID
echo -e "${GREEN}启动任务流管理器...${NC}"
echo -e "${BLUE}执行命令: ${CMD}${NC}"
nohup bash -c "$CMD" > "$log_file" 2>&1 &
PID=$!
## 保存PID到logs目录下的文件
echo $PID > ${pid_file}
echo -e "${GREEN}任务流已在后台启动,PID: ${PID}${NC}"
echo -e "${BLUE}PID保存至: ${pid_file}${NC}"
echo -e "${BLUE}要查看日志,请运行: tail -f ${log_file}${NC}"
echo -e "${BLUE}要终止进程,请运行: $0 stop ${TASK_CONFIG}${NC}"
;;
stop)
# 打印标题
echo -e "${BLUE}===========================================${NC}"
echo -e "${RED}TaskFlow进程终止工具${NC}"
echo -e "${BLUE}===========================================${NC}"
# 首先检查logs目录下的PID文件是否存在
if [ -f ${pid_file} ]; then
PID=$(cat ${pid_file})
echo -e "${BLUE}找到PID文件: ${pid_file}${NC}"
if ps -p $PID > /dev/null; then
echo -e "${YELLOW}进程正在运行 (PID: $PID)${NC}"
echo -e "${RED}正在终止进程...${NC}"
kill -9 $PID
rm ${pid_file}
echo -e "${GREEN}✓ 进程已成功终止${NC}"
echo -e "${GREEN}✓ 已删除PID文件${NC}"
else
echo -e "${YELLOW}PID文件存在,但进程 (PID: $PID) 已不存在${NC}"
rm ${pid_file}
echo -e "${GREEN}✓ 已清理PID文件${NC}"
fi
else
echo -e "${YELLOW}未找到PID文件: ${pid_file}${NC}"
echo -e "${BLUE}尝试查找TaskFlow进程...${NC}"
# 检查是否存在taskflow命令
if command -v taskflow &> /dev/null; then
echo -e "${BLUE}检查taskflow命令启动的进程...${NC}"
TASKFLOW_PID=$(ps aux | grep "[t]askflow.*${config_file}" | grep "$target_dir" | awk '{print $2}')
if [ ! -z "$TASKFLOW_PID" ]; then
echo -e "${YELLOW}找到taskflow进程 (PID: $TASKFLOW_PID)${NC}"
echo -e "${RED}正在终止进程...${NC}"
kill -9 $TASKFLOW_PID
echo -e "${GREEN}✓ 进程已成功终止${NC}"
else
echo -e "${YELLOW}未找到使用taskflow命令启动的进程${NC}"
fi
fi
# 检查Python脚本启动的进程
echo -e "${BLUE}检查Python脚本启动的进程...${NC}"
PYTHON_PID=$(ps aux | grep "[p]ython.*${SCRIPT_NAME}.*${config_file}" | grep "$target_dir" | awk '{print $2}')
if [ ! -z "$PYTHON_PID" ]; then
echo -e "${YELLOW}找到Python进程 (PID: $PYTHON_PID)${NC}"
echo -e "${RED}正在终止进程...${NC}"
kill -9 $PYTHON_PID
echo -e "${GREEN}✓ 进程已成功终止${NC}"
else
echo -e "${YELLOW}未找到使用Python启动的${SCRIPT_NAME}进程${NC}"
fi
fi
# 查找子进程 - 更通用的方法
echo -e "${BLUE}查找可能的子进程...${NC}"
# 获取所有Python进程
CHILD_PROCESSES=$(ps aux | grep "[p]ython" | grep "$target_dir" | grep -v "taskflow\|${SCRIPT_NAME}\|grep" | awk '{print $2}')
if [ ! -z "$CHILD_PROCESSES" ]; then
echo -e "${YELLOW}发现Python子进程:${NC}"
ps aux | grep "[p]ython" | grep "$target_dir" | grep -v "taskflow\|${SCRIPT_NAME}\|grep" | awk '{printf " PID: %s CMD: %s\n", $2, $11}'
# 终止所有子进程
for pid in $CHILD_PROCESSES; do
echo -e "${RED}正在终止子进程 (PID: $pid)...${NC}"
kill -9 $pid
done
echo -e "${GREEN}✓ 所有子进程已终止${NC}"
# 等待进程完全终止
echo -e "${BLUE}等待${WAIT_TIME}秒确保所有进程完全终止...${NC}"
sleep $WAIT_TIME
# 再次检查是否有残留进程
REMAINING=$(ps aux | grep "[p]ython" | grep "$target_dir" | grep -v "taskflow\|${SCRIPT_NAME}\|grep" | wc -l)
if [ $REMAINING -gt 0 ]; then
echo -e "${YELLOW}警告: 仍有${REMAINING}个进程未终止,请手动检查${NC}"
else
echo -e "${GREEN}✓ 确认所有进程已终止${NC}"
fi
else
echo -e "${GREEN}✓ 未发现Python子进程${NC}"
fi
echo -e "${GREEN}✓ 操作完成${NC}"
echo -e "${BLUE}===========================================${NC}"
;;
*)
echo -e "${RED}错误: 未知操作 ${ACTION}${NC}"
echo -e "支持的操作: start, stop"
exit 1
;;
esac