.net 程序通過 crontab 無法啟動手動執行腳本啟動的方法

一、問題描述

.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 &

到此這篇關於.net 程序通過 crontab 無法啟動手動執行腳本啟動的方法的文章就介紹到這瞭,更多相關.net  crontab 無法啟動內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!

推薦閱讀: