the*_*ter 6 python logging python-3.x python-logging
我正在使用带有日志记录模块的Python,并且想将socket.hostname()添加到每条日志消息中,我必须在每条消息中运行此查询并且不能使用
name = socket.hostname()
Run Code Online (Sandbox Code Playgroud)
然后用名称记录格式
我正在研究这个使用日志过滤器的示例,但我这里需要的不是过滤器,而是对每个日志消息的简单操作。
我怎样才能达到想要的结果?
这是建立在菲利普在使用时的答案的基础上的dictConfig
。本答案中演示的上下文过滤器用于psutil
在每个日志消息中记录当前的 CPU 和内存使用百分比。
将此文件保存为mypackage/util/logging.py
:
"""logging utiliies."""
import logging
from psutil import cpu_percent, virtual_memory
class PsutilFilter(logging.Filter):
"""psutil logging filter."""
def filter(self, record: logging.LogRecord) -> bool:
"""Add contextual information about the currently used CPU and virtual memory percentages into the given log record."""
record.psutil = f"c{cpu_percent():02.0f}m{virtual_memory().percent:02.0f}" # type: ignore
return True
Run Code Online (Sandbox Code Playgroud)
请注意,过滤功能对我不起作用;只有一个过滤器类起作用。
接下来,根据此答案更新您的日志记录配置字典,如下所示:
LOGGING_CONFIG = {
...,
"filters": {"psutil": {"()": "mypackage.util.logging.PsutilFilter"}},
"handlers": {"console": {..., "filters": ["psutil"]}},
"formatters": {
"detailed": {
"format": "%(asctime)s %(levelname)s %(psutil)s %(process)x:%(threadName)s:%(name)s:%(lineno)d:%(funcName)s: %(message)s"
}
},
}
Run Code Online (Sandbox Code Playgroud)
尝试记录一些内容,并查看示例输出,例如:
2020-05-16 01:06:08,973 INFO c68m51 3c:MainThread:mypackage.mymodule:27:myfunction: This is my log message.
Run Code Online (Sandbox Code Playgroud)
在上面的消息中,c68m51
表示 CPU 使用率 68%,内存使用率 51%。
您可以使用过滤器向每条消息添加信息:
import logging
import socket
class ContextFilter(logging.Filter):
def filter(self, record):
record.hostname = socket.gethostname()
return True
if __name__ == '__main__':
levels = (logging.DEBUG, logging.INFO, logging.WARNING, logging.ERROR, logging.CRITICAL)
logging.basicConfig(level=logging.DEBUG,
format='%(asctime)-15s hostname: %(hostname)-15s : %(message)s')
a1 = logging.getLogger('a.b.c')
f = ContextFilter()
a1.addFilter(f)
a1.debug('A debug message')
Run Code Online (Sandbox Code Playgroud)
归档时间: |
|
查看次数: |
4022 次 |
最近记录: |