python3使用logging包,如何把日志寫到系統(tǒng)的rsyslog中
使用logging包,把日志寫到系統(tǒng)的rsyslog中
最近要寫一個python程序?qū)懭罩镜絩syslog中,并通過配置rsyslog的文件來將他存到一個指定文件中。
首先,我想來看看logging提供的常用模塊:
logger
logger主要是用來配置和發(fā)送日志消息的。
可通過logging.getLogger(name)來返回一個logger對象。
不指定name就默認為root。
這里可以取一個合適的名字。
相同的name會返回同一個logger對象。
在Formatter方法中用%(name)s在日志中打印出這個name。
例如:
log = logging.getLogger('mylog')
log_format = logging.Formatter(
'hhl-%(name)s-server[%(process)d]-%(levelname)s: %(message)s')
#打印結(jié)果示例:
#Aug 2 12:44:41 [localhost] hhl-mylog-server[7409]-DEBUG: debug messagehandler
將日志記錄發(fā)送到目的地,如文件,socket等。
這里可以通過addHandler方法添加多個handler,可以實現(xiàn)日志的分級過濾。
如果要把日志發(fā)送到rsyslog中,就可以采用SysLogHandler(),使用這個方法前需要導(dǎo)入他
from logging.handlers import SysLogHandler
這個方法有兩個參數(shù)、一個是rsyslog中的facility:指定的是發(fā)送的設(shè)備,如kernel,mail,system等等,他還有l(wèi)ocal0-local7預(yù)留。
這里我采用local5。
還有一個參數(shù)指定的是log程序的地址,在centos7上默認是/dev/log。
示例如下:
log_hdlr=SysLogHandler(facility=SysLogHandler.LOG_LOCAL5, address='/dev/log')
對應(yīng)的rsyslog設(shè)置文件(/etc/rsyslog.conf):
local5.* /var/log/all.log #將local5的所有日志存入all.log文件中
如果想用handler對日志信息進行過濾
可以這樣:
log_hdlr.setLevel(logging.ERROR) #這里就指定了接收error以及更高級別的日志
formatter
指定日志的輸出格式,包括消息格式和日期字符格式
例如:
log_format = logging.Formatter(
'hhl-%(name)s-server[%(process)d]-%(levelname)s: %(message)s')
#輸出示例
#Aug 2 12:44:41 [localhost] hhl-mylog-server[7409]-DEBUG: debug messageformatter可調(diào)用參數(shù)有:
%(name)sLogger的名字%(levelname)s文本形式的日志級別%(message)s用戶輸出的消息%(asctime)s字符串形式的當(dāng)前時間。默認格式是 “2003-07-08 16:49:45,896”。逗號后面的是毫秒%(levelno)s數(shù)字形式的日志級別%(pathname)s調(diào)用日志輸出函數(shù)的模塊的完整路徑名,可能沒有%(filename)s調(diào)用日志輸出函數(shù)的模塊的文件名%(module)s調(diào)用日志輸出函數(shù)的模塊名%(funcName)s調(diào)用日志輸出函數(shù)的函數(shù)名%(lineno)d調(diào)用日志輸出函數(shù)的語句所在的代碼行%(created)f當(dāng)前時間,用UNIX標(biāo)準(zhǔn)的表示時間的浮 點數(shù)表示%(relativeCreated)d輸出日志信息時的,自Logger創(chuàng)建以 來的毫秒數(shù)%(thread)d線程ID??赡軟]有%(threadName)s線程名??赡軟]有%(process)d進程ID??赡軟]有
由上面的這些模塊就可以實現(xiàn)我想要的功能啦
將日志寫入到all.log文件中-----
源代碼
import logging
from logging.handlers import SysLogHandler
log = logging.getLogger('mylog')
log.setLevel(logging.DEBUG)
log_hdlr=SysLogHandler(facility=SysLogHandler.LOG_LOCAL5, address='/dev/log')
log_format = logging.Formatter(
'hhl-%(name)s-server[%(process)d]-%(levelname)s: %(message)s')
log_hdlr.setFormatter(log_format)
log_hdlr.setLevel(logging.ERROR)#接受error及以上的日志信息
log.addHandler(log_hdlr)
log.debug('debug message test')#指明級別為debug
log.error('error message test')#指明級別為error
#最后只保存error及更高優(yōu)先級的日志總結(jié)
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
python字符串編碼識別模塊chardet簡單應(yīng)用
有時候需要先檢測一個文件的編碼,然后將其轉(zhuǎn)化為另一種編碼。這時候就會用到chardet(chardet是python的一個第三方庫,是非常優(yōu)秀的編碼識別模塊)2015-06-06
如何使Python中的print()語句運行結(jié)果不換行
這篇文章主要介紹了如何使Python中的print()顯示當(dāng)前語句后不換行,print() 是一個常用函數(shù),但是每次,print()語句顯示后都會換行,本問我們就來節(jié)日如何使print()顯示當(dāng)前語句后不換行,需要的朋友可以參考一下2022-03-03

