正文

 

  本文記錄了因?yàn)橐粋€(gè)簡(jiǎn)單的日志需求,繼而對(duì)linux環(huán)境下syslog、rsyslog、unix domain socket的學(xué)習(xí)。本文關(guān)注使用層面,并不涉及rsyslog的實(shí)現(xiàn)原理,感興趣的讀者可以參考rsyslog官網(wǎng)。另外,本文實(shí)驗(yàn)的環(huán)境實(shí)在debian8,如果是其他linux發(fā)行版本或者debian的其他版本,可能會(huì)稍微有些差異。

需求:

回到頂部

  工作中有一個(gè)在Linux(debian8)環(huán)境下運(yùn)行的服務(wù)器程序,用python語(yǔ)言實(shí)現(xiàn),代碼中有不同優(yōu)先級(jí)的日志需要記錄,開(kāi)發(fā)的時(shí)候都是使用python的logging模塊輸出到文件,示例代碼如下:

  

大學(xué)生就業(yè)培訓(xùn),高中生培訓(xùn),在職人員轉(zhuǎn)行培訓(xùn),企業(yè)團(tuán)訓(xùn)

 1 import logging, os 2  3 logger = None 4 def get_logger(): 5     global logger 6     if not logger: 7         logger = logging.getLogger('ServerLog') 8         logger.setLevel(logging.INFO) 9         filehandler = logging.FileHandler(os.environ['HOME'] + '/Server.log', encoding='utf8')10         filehandler.setFormatter(logging.Formatter("%(asctime)s - %(levelname)s - %(message)s"))11         logger.addHandler(filehandler)12     return logger13