.net 程式通過 crontab 無法啟動,手動執行指令碼可以啟動

神奇二進位制發表於2021-12-24

一、問題描述

.net 閘道器程式需要設定定時重啟,按照日常操作先把正在執行的 PID kill 掉後,再執行啟動服務。

把指令碼放到 crontab 計劃任務上,可以把服務 PID kill 掉,但無法啟動服務,直接手動執行指令碼是可以成功啟動的。

.net 服務重啟指令碼test1.sh 如下:

[root@localhost ~]# cat test1.sh 
#!/bin/bash

ID=`ps -ef | grep YTGateWayServiceZZ| grep -v "grep" | awk '{print $2}'`
for id in $ID;
do
kill -9 $id
done

sleep 3;
nohup dotnet /home/gateway1/YTGateWayServiceZZ.dll  > /dev/null 2>&1 &

通過指令碼無法啟動,試著把 .net 程式寫成服務後,發現是可以正常重啟的。

二、將 .net 程式寫成服務

先把原來通過執行路徑方式啟動的服務 kill 掉之後,再執行 config.sh 指令碼把程式寫成服務;

並寫入 crontab 計劃任務中,通過測試是可以正常重啟程式。

[root@localhost ~]# cat config.sh
#!/bin/bash

# 找到 dotnet 命令位置
dotnet=`which dotnet`

# 將 .net core 寫成服務方式執行
cat > /usr/lib/systemd/system/gateway1.service << EOF
[Unit]
# 服務描述
Description=gateway1 YTGateWayServiceZZ

[Service]
# 程式工作路徑
WorkingDirectory=/home/gateway1
# 啟動程式路徑
ExecStart= $dotnet /home/gateway1/YTGateWayServiceZZ.dll
Restart=always
# 如果 dotnet 服務崩潰,10秒後重新啟動服務
RestartSec=10

[Install]
# 系統執行級別
WantedBy=multi-user.target
EOF

# 寫入 crontab 計劃任務(6個小時重啟一次)
crontab -l > conf && echo "0 */6 * * * systemctl restart gateway1.service " >> conf && crontab conf && rm -f conf

執行指令碼 config.sh

[root@localhost ~]# chmod +x config.sh
[root@localhost ~]# ./config.sh

管理自定義服務命令

# systemctl status gateway1.service
# systemctl start gateway1.service
# systemctl restart gateway1.service
# systemctl enable gateway1.service

三、通過 crontab 執行指令碼無法啟動原因

通過將 .net 程式寫成服務測試之後,初步判斷很有可能是 crontab 執行時沒有找到系統環境變數導致的。

檢查了指令碼發現只有 dotnet 命令沒有使用絕對路徑,試著把 dotnet 命令加上絕對路徑結果可以成功啟動了。

[root@localhost ~]# which dotnet
/usr/local/bin/dotnet
[root@localhost ~]# cat test1.sh 
#!/bin/bash

ID=`ps -ef | grep YTGateWayService| grep -v "grep" | awk '{print $2}'`
for id in $ID;
do
kill -9 $id
done

sleep 3;
nohup /usr/local/bin/dotnet  /root/publish/YTGateWayService.dll  > /dev/null 2>&1 &

相關文章