默认数据格式
默认情况下,采用tornado的web框架运行起来之后,任何访问都会直接在控制台输出日志信息,格式如下:
[I 160807 09:27:17 web:1971] 200 GET / (::1) 7.00ms
[I 160807 09:27:23 web:1971] 200 GET /login (::1) 12.00ms
这条日志的信息量其实不小,每个字段的含义分别是:
源数据 | 含义 |
---|---|
I | INFO |
160807 | 日期 |
09:27:23 | 具体时间 |
web | 模块名称 |
1971 | 在第几行执行打印输出的这条日志信息 |
200 GET / (::1) 7.00ms | 输出的内容. |
期望数据格式
按照我理想中的日志格式,细化下来应该是这个样子的:
[2016-08-07 09:38:01 执行文件名:执行函数名:执行行数 日志等级] 内容消息
解决办法
经过近3个小时的stackoverflow搜索(其实没有结果)、翻看官网介绍以及源码分析,最终我的实现方式是:
- 在启动文件(main.py)中创建一个日志格式类(继承tornado.log.LogFormatter).
- 重新定义输出格式(具体请参考下面提供的样例代码).
- 重置logger.ha