Ami*_*ler 4 python logging json
我想将logging.config.dictConfig与 json 配置文件一起使用。但我想使用另一个类的格式化程序:pythonjsonlogger.jsonlogger.JsonFormatter
这段代码/json 有什么问题:
$ cat test.json
{
"version": 1,
"disable_existing_loggers": "true",
"formatters": {
"json": {
"class": "pythonjsonlogger.jsonlogger.JsonFormatter"
# also tried "jsonlogger.JsonFormatter" (comment not in real file)
}
},
"handlers": {
"console": {
"class": "logging.StreamHandler",
"level": "DEBUG",
"formatter": "json",
"stream": "ext://sys.stdout"
}
},
"loggers": { },
"root": {
"handlers": ["console"],
"level": "DEBUG"
}
}
Run Code Online (Sandbox Code Playgroud)
代码:
import sys
sys.path.append('/usr/local/lib/python2.7/site-packages')
import json
import logging
import logging.config
from pythonjsonlogger import jsonlogger
fp = open('/test.json')
logging.config.dictConfig(json.load(fp))
fp.close()
logging.info('test log line')
Run Code Online (Sandbox Code Playgroud)
输出:
test log line
Run Code Online (Sandbox Code Playgroud)
预期类似 { "message": "test log line" }
好吧,很有趣,但有效:
杰森:
{
"version": 1,
"disable_existing_loggers": true,
"formatters": {
"json": {
"()": "pythonjsonlogger.jsonlogger.JsonFormatter"
}
},
"handlers": {
"json": {
"class": "logging.StreamHandler",
"formatter": "json"
}
},
"loggers": {
"": {
"handlers": ["json"],
"level": 20
}
}
}
Run Code Online (Sandbox Code Playgroud)
代码:
import logging_util as safe_logging
import logging.config
import json
fp = open("logger_config.json")
config = json.load(fp)
fp.close()
logging.config.dictConfig(config)
safe_logging.via_logger = logging.getLogger("JsonLogger")
safe_logging.info("event")
Run Code Online (Sandbox Code Playgroud)
格式化程序也可以有一个格式,不确定如何,但它有效:
"json": {
"()": "pythonjsonlogger.jsonlogger.JsonFormatter",
"format": "%(asctime)s %(levelname)s %(filename)s %(lineno)s %(message)s"
}
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
3480 次 |
| 最近记录: |