Python 日志记录 如何在日志中跟踪主机名?

Python logging how to track hostname in logs?

我正在使用 Python 以这种方式登录:

logger = logging.getLogger("my_logger")
logger.info("Some text.")

我有一堆物联网设备 运行(制作日志)。他们将日志数据流式传输到数据库。为了区分来源,我需要包括源IP地址。

有没有办法使用日志记录获取主机名? LogRecords 中的 IP 地址或主机名 tracked/trackable?

一般来说,将主机名添加到 LogRecord 的最佳方法是什么?

您可以通过添加将主机名放入日志消息中的自定义日志过滤器和格式化程序来实现。

import logging, platform

class HostnameFilter(logging.Filter):
    hostname = platform.node()

    def filter(self, record):
        record.hostname = HostnameFilter.hostname
        return True

handler = logging.StreamHandler()
handler.addFilter(HostnameFilter())
handler.setFormatter(logging.Formatter('%(asctime)s %(hostname)s: %(message)s', datefmt='%b %d %H:%M:%S'))

logger = logging.getLogger()
logger.addHandler(handler)
logger.setLevel(logging.INFO)

logger.info('Hello, world!')

一个更简单的解决方案是 pre-populate 带有主机名的格式行。例如:

logging.basicConfig(
   #... your logging configuration,
   format="%(asctime)s {} %(message)s".format(socket.gethostname())
)

会生成像

这样的格式行
"%(asctime)s some-hostname %(message)s"

缺点是如果主机名更改,您需要重新启动 service/application。对于大多数应用程序来说,这通常不是问题,特别是如果 运行 on docker/k8s