python 写日志文件

摘要: 项目的开发过程中,日志文件是少不了的,通过写日志文件,可以知道程序运行的情况。特别当部署在生产环境中的时候,这个时候一般不能debug , 当然在有些情况时可以 remote debug (远程debug)。那种情况另当别论。还是用通常的写日志的方法,比如在 java 中,经常可以看到 log4j,sf4j,logback等三方组件来写日志。在python中如何实现呢,其实python 本身也带了日志操作的库。可以直接使用。这里我把在项目中用到的整理了一下,分享在下面,这个实现的方法,主要有两点1. 写日志的类2.日志配置文件(handler,logger,以及日志保存的路径等)

项目的开发过程中,日志文件是少不了的,通过写日志文件,可以知道程序运行的情况。特别当部署在生产环境中的时候,这个时候一般不能debug , 当然在有些情况时可以 remote debug (远程debug)。那种情况另当别论。还是用通常的写日志的方法,比如在 java 中,经常可以看到 log4j,sf4j,logback等三方组件来写日志。

在python中如何实现呢,其实python 本身也带了日志操作的库。可以直接使用。这里我把在项目中用到的整理了一下,分享在下面,这个实现的方法,主要有两点
1. 写日志的类
2.日志配置文件(handler,logger,以及日志保存的路径等)

写日志的类

'''
Created on 2012-2-17
@author: yihaomen.com
'''
import logging.config
import os

class INetLogger:       
    log_instance = None        
    @staticmethod
    def InitLogConf():
        currentDir=os.path.dirname(__file__) 
        INetLogger.log_instance = logging.config.fileConfig(currentDir+os.path.sep+"logger.ini")
   
    @staticmethod
    def GetLogger(name = ""):
        if INetLogger.log_instance == None:
            INetLogger.InitLogConf()
        INetLogger.log_instance = logging.getLogger(name)
        return INetLogger.log_instance
   
if __name__ == "__main__": 
    logger = INetLogger.GetLogger()    
    logger.debug("debug message")
    logger.info("info message")
    logger.warn("warn message")
    logger.error("error message")
    logger.critical("critical message")   
    logHello = INetLogger.GetLogger("root")
    logHello.info("Hello world!")


日志配置文件,与上面的类在同一文件夹下 logger.ini
[loggers]
keys=root,mysql,socket
 
[handlers]
keys=consoleHandler,rotateFileHandler
 
[formatters]
keys=simpleFormatter
 
[formatter_simpleFormatter]
format=[%(asctime)s][%(levelname)s] [%(filename)s:%(lineno)d] [thread:%(thread)d]: %(message)s
 
[logger_root]
qualname=root
level=DEBUG
handlers=consoleHandler,rotateFileHandler
 
[logger_mysql]
qualname=mysql
level=DEBUG
handlers=rotateFileHandler
 
[logger_socket]
qualname=socket
level=ERROR
handlers=rotateFileHandler
 
[handler_consoleHandler]
class=StreamHandler
level=DEBUG
formatter=simpleFormatter
args=(sys.stdout,)
 
[handler_rotateFileHandler]
class=handlers.RotatingFileHandler
level=DEBUG
formatter=simpleFormatter
args=('c:/logs/InetServer.log', 'a', 2000000, 9)


如果你用了 handler_rotateFileHandler 的话,这样日志就会保存到 才c:/logs/InetServer.log 文件里面,而且当日志超过2000000 d的时候,重新另外生成一个文件,保存9天的记录,你可以配置成30,这样就保存了最近一个月的日志记录。

上一篇: 美化html fieldset legent(CSS 样式附源码下载)
下一篇: delphi 生成网页(html)报表
 评论 ( What Do You Think )
名称
邮箱
网址
评论
验证
   
 

 


  • 微信公众号

  • 我的微信

站点声明:

1、一号门博客CMS,由Python, MySQL, Nginx, Wsgi 强力驱动

2、部分文章或者资源来源于互联网, 有时候很难判断是否侵权, 若有侵权, 请联系邮箱:summer@yihaomen.com, 同时欢迎大家注册用户,主动发布无版权争议的 文章/资源.

3、鄂ICP备14001754号-3, 鄂公网安备 42280202422812号