业精于勤,荒于嬉;行成于思,毁于随。
我已經解決了上面的問題,那就是在腳本裡新增「刪除lock文件,新建lock檔案」的語句。我發現每次lock檔案是新的時候才會觸發crontab。
從圖表可見,只要偵測是目前時間出現499 就會觸發一個叫做nginxchen.sh的腳本,這個腳本執行時間大約8分鐘。
說實話,我也不知道你這個具體是什麼原因,借用一句話:實踐是檢驗真理的唯一標準,因此我模擬了樓主的場景
1.寫一個執行超過2分鐘的腳本,然後執行
2.放到crontab*/1 * * * * flock -xn /root/xx.lock -c 'sh /root/xx.sh >>/tmp/xx.log 2>&1'
3.查看crontab執行內容
可以發現,並沒有樓主所說的問題
因此有以下建議:1.編寫一個簡短的腳本在伺服器上面測試,如果不行,就換台伺服器,看看是否狀況相同2.查看/mnt/499.log 日誌有無異常輸出3.查看進程是否一直在運行或卡死導致crontab無法拿到鎖
就以上這些了,如果樓主自己找到原因,不要忘記貼出來啊
我已經解決了上面的問題,那就是在腳本裡新增「刪除lock文件,新建lock檔案」的語句。我發現每次lock檔案是新的時候才會觸發crontab。
從圖表可見,只要偵測是目前時間出現499 就會觸發一個叫做nginxchen.sh的腳本,這個腳本執行時間大約8分鐘。
說實話,我也不知道你這個具體是什麼原因,借用一句話:實踐是檢驗真理的唯一標準,因此我模擬了樓主的場景
1.寫一個執行超過2分鐘的腳本,然後執行
2.放到crontab
*/1 * * * * flock -xn /root/xx.lock -c 'sh /root/xx.sh >>/tmp/xx.log 2>&1'
3.查看crontab執行內容
可以發現,並沒有樓主所說的問題
因此有以下建議:
1.編寫一個簡短的腳本在伺服器上面測試,如果不行,就換台伺服器,看看是否狀況相同
2.查看/mnt/499.log 日誌有無異常輸出
3.查看進程是否一直在運行或卡死導致crontab無法拿到鎖
就以上這些了,如果樓主自己找到原因,不要忘記貼出來啊