這篇文章將為大家詳細講解有關如何在Python中使用syslog日志,文章內(nèi)容質(zhì)量較高,因此小編分享給大家做個參考,希望大家閱讀完這篇文章后對相關知識有一定的了解。
10年積累的網(wǎng)站設計、做網(wǎng)站經(jīng)驗,可以快速應對客戶對網(wǎng)站的新想法和需求。提供各種問題對應的解決方案。讓選擇我們的客戶得到更好、更有力的網(wǎng)絡服務。我雖然不認識你,你也不認識我。但先網(wǎng)站制作后付款的網(wǎng)站建設流程,更有上栗免費網(wǎng)站建設讓你可以放心的選擇與我們合作。該模塊的主要方式為:
#!/usr/bin/python # -*- coding: utf-8 -*- import syslog syslog.openlog([ident[, logoption[, facility]]]) syslog.syslog(priority, message) syslog.closelog()
ident 的信息為 /bluedon/test.py
logoption 的信息為 [4642]
facility 的信息為 記錄日志文件的位置 ,本文選取的 facility = syslog.LOG_USER ,即日志輸出在 /var/log/messages
源碼為:
#!/usr/bin/python # -*- coding: utf-8 -*- import syslog import os if __name__ == '__main__': # https://docs.python.org/2/library/syslog.html # syslog.openlog([ident[, logoption[, facility]]]) # ident filename = os.path.abspath(__file__) # logoption # LOG_CONS:如果將信息發(fā)送給守護進程時發(fā)生錯誤,直接將相關信息輸入到相關信息輸出到終端。 # LOG_NDELAY:立即打開與系統(tǒng)日志的連接(通常情況下,只有在產(chǎn)生第一條日志信息的情況下才會打開與日志系統(tǒng)的連接) # LOG_NOWAIT:在記錄日志信息時,不等待可能的子進程的創(chuàng)建 # LOG_ODELAY:類似于LOG_NDELAY參數(shù),與系統(tǒng)日志的連接只有在syslog函數(shù)調(diào)用時才會創(chuàng)建 # LOG_PID:每條日志信息中都包括進程號 # LOG_PID, LOG_CONS, LOG_NDELAY, LOG_NOWAIT, LOG_PERROR pid = syslog.LOG_PID # facility # LOG_KERN, LOG_USER, LOG_MAIL, LOG_DAEMON, LOG_AUTH, LOG_LPR, LOG_NEWS, LOG_UUCP, LOG_CRON, LOG_SYSLOG, LOG_LOCAL0 to LOG_LOCAL7 filepath = syslog.LOG_USER # Priority # LOG_EMERG, LOG_ALERT, LOG_CRIT, LOG_ERR, LOG_WARNING, LOG_NOTICE, LOG_INFO, LOG_DEBUG level = syslog.LOG_NOTICE # messages messages = "test start14" # syslog.openlog([ident[, logoption[, facility]]]) syslog.openlog(filename, pid, filepath) # syslog.syslog(priority, message) syslog.syslog(level, messages) # close syslog syslog.closelog() # vim var/log/message # tail -f /tmp/syslog.txt
在不同機器上面查看結果:
將其寫成了類
#!/usr/bin/python # -*- coding: utf-8 -*- import syslog class mysyslog(object): # level # LOG_EMERG, LOG_ALERT, LOG_CRIT, LOG_ERR, LOG_WARNING, LOG_NOTICE, LOG_INFO, LOG_DEBUG debug = syslog.LOG_DEBUG info = syslog.LOG_INFO notice = syslog.LOG_NOTICE warning = syslog.LOG_WARNING err = syslog.LOG_ERR crit = syslog.LOG_CRIT alert = syslog.LOG_ALERT emerg = syslog.LOG_EMERG # logoption # LOG_PID, LOG_CONS, LOG_NDELAY, LOG_NOWAIT, LOG_PERROR # LOG_CONS:如果將信息發(fā)送給守護進程時發(fā)生錯誤,直接將相關信息輸入到相關信息輸出到終端。 # LOG_NDELAY:立即打開與系統(tǒng)日志的連接(通常情況下,只有在產(chǎn)生第一條日志信息的情況下才會打開與日志系統(tǒng)的連接) # LOG_NOWAIT:在記錄日志信息時,不等待可能的子進程的創(chuàng)建 # LOG_ODELAY:類似于LOG_NDELAY參數(shù),與系統(tǒng)日志的連接只有在syslog函數(shù)調(diào)用時才會創(chuàng)建 # LOG_PID:每條日志信息中都包括進程號 cons = syslog.LOG_CONS ndelay = syslog.LOG_NDELAY nowait = syslog.LOG_NOWAIT pid = syslog.LOG_PID # facility # LOG_KERN, LOG_USER, LOG_MAIL, LOG_DAEMON, LOG_AUTH, LOG_LPR, LOG_NEWS, LOG_UUCP, LOG_CRON, LOG_SYSLOG, LOG_LOCAL0 to LOG_LOCAL7 # kern = syslog.LOG_KERN # user = syslog.LOG_USER # mail = syslog.LOG_MAIL # daemon = syslog.LOG_DAEMON # auth = syslog.LOG_AUTH # lpr = syslog.LOG_LPR # news = syslog.LOG_NEWS # uucp = syslog.LOG_UUCP # cron = syslog.LOG_CRON # _syslog = syslog.LOG_SYSLOG @classmethod def __init__(self): pass @staticmethod def basicConfig(name, logoption): facility = syslog.LOG_USER syslog.openlog(name, logoption, facility) @staticmethod def tosyslog(level, ip, messages): newmessages = "[" + ip + "]" + " " + messages syslog.syslog(level, newmessages)
關于如何在Python中使用syslog日志就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。
另外有需要云服務器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內(nèi)外云服務器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務器、裸金屬服務器、高防服務器、香港服務器、美國服務器、虛擬主機、免備案服務器”等云主機租用服務以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務可用性高、性價比高”等特點與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應用場景需求。
標題名稱:如何在Python中使用syslog日志-創(chuàng)新互聯(lián)
鏈接URL:http://muchs.cn/article26/dgcdcg.html
成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站設計公司、Google、營銷型網(wǎng)站建設、網(wǎng)站建設、網(wǎng)站設計、企業(yè)建站
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉載內(nèi)容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉載,或轉載時需注明來源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內(nèi)容