我还没有找到对自己满意的Django设置Python日志记录的方法。我的要求很简单:
我当前的设置是使用logging.conf文件,然后在我登录的每个模块中记录设置。感觉不对。
logging.conf
您是否有喜欢的日志记录设置?请详细说明:如何设置配置(logging.conf在代码中使用或设置),在何处/何时启动记录器,以及如何在模块中访问它们等等。
到目前为止,我发现的最好方法是在settings.py中初始化日志记录设置-其他地方。您可以使用配置文件,也可以分步进行编程- 这仅取决于您的要求。关键是我通常使用级别和有时记录日志的方式将我想要的处理程序添加到根记录器中。过滤器将我想要的事件获取到适当的文件,控制台,系统日志等。您当然可以将处理程序添加到任何其他记录器中同样,但根据我的经验,通常不需要这样做。
在每个模块中,我都使用
logger = logging.getLogger(__name__)
并将其用于记录模块中的事件(并且,如果我想进一步区分),请使用记录器,该记录器是上面创建的记录器的子级。
如果我的应用程序可能会在未配置settings.py中配置日志记录的站点中使用,请在以下位置定义NullHandler:
#someutils.py class NullHandler(logging.Handler): def emit(self, record): pass null_handler = NullHandler()
并确保将其实例添加到我的应用程序中使用日志记录的模块中创建的所有记录器中。(注意:NullHandler已经在Python 3.1的日志记录包中,并且将在Python 2.7中使用。)
logger = logging.getLogger(__name__) logger.addHandler(someutils.null_handler)
这样做是为了确保您的模块在未配置settings.py日志记录的站点中正常运行,并且不会收到任何令人讨厌的“找不到XYZ记录程序的处理程序”消息(这些警告可能会配置错误的日志记录)。
这样做可以满足您规定的要求:
getLogger(__name__)
settings.py
更新: 请注意,从1.3版开始,Django现在合并了对logging的支持。