摘要:最近用寫了一些數據統計的腳本,并使用自動執行,但是配置總是要過幾個坑才行的,這里總結一下這次遇到的坑。路徑我們在寫腳本時往往會使用相對路徑,但是在執行腳本時,由于工作目錄不同,就會出現找不到文件或者目錄不存在的問題。
最近用Python寫了一些數據統計的腳本,并使用crontab自動執行,但是配置crontab總是要過幾個坑才行的,這里總結一下這次遇到的坑。
輸出要將crontab命令的輸出記錄到日志文件中,可以使用重定向,不僅要重定向stdout也要重定向stderr,因為Python解釋器會將異常輸出到stderr。示例:
$HOME/path/to/script > $HOME/log/file 2>&1環境變量
crontab會以用戶的身份執行配置的命令,但是不會加載用戶的環境變量,crontab會設置幾個默認的環境變量,例如SHELL、PATH和HOME等,一定要注意PATH可不是用戶自定義的PATH。
我們往往會在.bash_profile文件中定義一些全局的環境變量,但是crontab執行時并不會加載這個文件,所以你在shell中正常執行的程序,放到crontab里就不行了,很可能就是因為找不到環境變量了。要解決這個問題只能是自己加載環境變量了,可以在shell腳本中添加source $HOME/.bash_profile,或者直接添加到crontab中。
0 12 * * * source $HOME/.bash_profile && $HOME/path/to/script > $HOME/log/file 2>&1路徑
我們在寫腳本時往往會使用相對路徑,但是在crontab執行腳本時,由于工作目錄不同,就會出現找不到文件或者目錄不存在的問題。
解決方法是腳本中使用絕對路徑或者在執行程序前切換工作目錄,例如直接在crontab命令中切換工作目錄:
0 12 * * * source $HOME/.bash_profile && cd $HOME/path/to/workdir && ./script > /HOME/log/file 2>&1編碼
我寫的Python程序中輸出了一些中文(編碼是utf-8),在shell中直接執行沒有問題,但是crontab執行時出現了UnicodeEncodeError的錯誤,Google了一下發現這個問題不僅僅是在crontab中會出現,在使用管道或者重定向的時候都會出現這個問題,原因是編碼不同。
在終端中直接執行Python程序時,Python會將輸出內容自動編碼為終端所使用的編碼,我使用的終端編碼是utf-8,所以不會出錯,輸出的內容也是正常的。但是在使用管道或者重定向時,編碼格式為ascii,Python會用ascii編碼格式去encode輸出的字符串,但是字符串的編碼使用的時utf-8,所以會出現UnicodeEncodeError的錯誤。
解決方法:
方法一:在程序中輸出的字符串都加上encode("utf-8");
方法二:在crontab中加上PYTHONIOENCODING=utf-8,將Python的stdout/stderr/stdin編碼設置為utf-8。
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/37531.html
摘要:首先是添加群自定義機器人在釘釘上選擇需要發送消息的群,選擇群機器人添加機器人自定義機器人添加,如下圖如需要,可以為機器人設置頭像。 由于公司用的通訊工具是釘釘,而群機器人可以實現自動化的信息同步,因此這里總結了自己使用釘釘自定義機器人一些方法,供參考拋磚引玉。 首先是添加群自定義機器人 在釘釘上選擇需要發送消息的群,選擇群機器人-添加機器人-自定義機器人-添加,如下圖: showImg...
摘要:為系統增加的第一行代碼不會影響該腳本在下的運行,因此您也可以用該方法編寫跨平臺的腳本程序。指定會話頁面在客戶端中的有限期分鐘缺省下為分鐘。最原始的博主沒有找到,只能在此聲明,特為轉載。 這幾天需要用PHP寫一個定時抓取網頁的服務器應用. 在網上搜了一下解決辦法, 發現OSchina的 一個問題的解答很精彩(值得一看,謝謝大牛們的精彩回答O(∩_∩)O~), 提出幾種解決辦法.現總結如下...
摘要:在輪循任務完成后,已輪循的歸檔將使用進行壓縮。在日志輪循期間,任何錯誤將被忽略,例如文件無法找到之類的錯誤。在這種情況下,進程將立即再次讀取其配置并繼續運行。表示,每隔分鐘,執行打印一次命令第二步添加定時任務。 1、關于日志切割 日志文件包含了關于系統中發生的事件的有用信息,在排障過程中或者系統性能分析時經常被用到。對于忙碌的服務器,日志文件大小會增長極快,服務器會很快消耗磁盤空間,...
閱讀 784·2021-10-09 09:58
閱讀 647·2021-08-27 16:24
閱讀 1731·2019-08-30 14:15
閱讀 2392·2019-08-30 11:04
閱讀 2079·2019-08-29 18:43
閱讀 2173·2019-08-29 15:20
閱讀 2723·2019-08-26 12:20
閱讀 1622·2019-08-26 11:44