Python日志syslog使用原理詳解
這篇文章主要介紹了Python日志syslog使用原理詳解,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
syslog的官方說明在:
https://docs.python.org/2/library/syslog.html#module-syslog
該模塊的主要方式為:
#!/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ā)送給守護(hù)進(jìn)程時發(fā)生錯誤,直接將相關(guān)信息輸入到相關(guān)信息輸出到終端。 # LOG_NDELAY:立即打開與系統(tǒng)日志的連接(通常情況下,只有在產(chǎn)生第一條日志信息的情況下才會打開與日志系統(tǒng)的連接) # LOG_NOWAIT:在記錄日志信息時,不等待可能的子進(jìn)程的創(chuàng)建 # LOG_ODELAY:類似于LOG_NDELAY參數(shù),與系統(tǒng)日志的連接只有在syslog函數(shù)調(diào)用時才會創(chuàng)建 # LOG_PID:每條日志信息中都包括進(jìn)程號 # 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
在不同機(jī)器上面查看結(jié)果:
將其寫成了類
#!/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ā)送給守護(hù)進(jìn)程時發(fā)生錯誤,直接將相關(guān)信息輸入到相關(guān)信息輸出到終端。 # LOG_NDELAY:立即打開與系統(tǒng)日志的連接(通常情況下,只有在產(chǎn)生第一條日志信息的情況下才會打開與日志系統(tǒng)的連接) # LOG_NOWAIT:在記錄日志信息時,不等待可能的子進(jìn)程的創(chuàng)建 # LOG_ODELAY:類似于LOG_NDELAY參數(shù),與系統(tǒng)日志的連接只有在syslog函數(shù)調(diào)用時才會創(chuàng)建 # LOG_PID:每條日志信息中都包括進(jìn)程號 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)
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
關(guān)于Django ForeignKey 反向查詢中filter和_set的效率對比詳解
今天小編就為大家分享一篇關(guān)于Django ForeignKey 反向查詢中filter和_set的效率對比詳解,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-12-12python利用elaphe制作二維條形碼實現(xiàn)代碼
條形碼的應(yīng)用將會越來越廣泛,看到了一篇文章,寫的挺好的!用手機(jī)拍二維碼,查二維碼確實很爽!這將成為一種潮流2012-05-05python單例模式之selenium driver實現(xiàn)單例
這篇文章主要介紹了python單例模式之selenium driver實現(xiàn)單例,使用裝飾器實現(xiàn)單例,文章基于python的相關(guān)資料實現(xiàn)主題,具有一的的參考價值,需要的朋友可以參考一下2022-03-03Python 使用SFTP和FTP實現(xiàn)對服務(wù)器的文件下載功能
這篇文章主要介紹了Python 使用SFTP和FTP實現(xiàn)對服務(wù)器的文件下載功能,本文通過實例代碼給大家介紹的非常想詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-12-12