python:测试将日志发送到Syslog服务器

时间:2020-04-29 09:47:32

标签: python syslog python-logging

请帮助我,如何将python脚本日志发送到syslog服务器(syslog-ng产品),我已经尝试过以下方法。它有两种方法。一种是“ SysLogHandler”,另一种是“ SocketHandler”

import logging
import logging.handlers
import socket

my_logger = logging.getLogger('MyLogger')
my_logger.setLevel(logging.DEBUG)

handler = logging.handlers.SysLogHandler(address=('10.10.11.11', 611), socktype=socket.SOCK_STREAM)
#handler = logging.handlers.SocketHandler('10.10.11.11', 611)

my_logger.addHandler(handler)

my_logger.debug('this is debug')
my_logger.critical('this is critical')

结果:用于SysLogHandler

[ansible@localhost ~]$ python test.py
Traceback (most recent call last):
  File "test.py", line 8, in <module>
    handler = logging.handlers.SysLogHandler(address=('10.10.11.11', 611), socktype=socket.SOCK_STREAM)
  File "/usr/lib64/python3.6/logging/handlers.py", line 847, in __init__
    raise err
  File "/usr/lib64/python3.6/logging/handlers.py", line 840, in __init__
    sock.connect(sa)
ConnectionRefusedError: [Errno 111] Connection refused #THIS IS OK for me since server unreachable.
Error in atexit._run_exitfuncs:
Traceback (most recent call last):
  File "/usr/lib64/python3.6/logging/__init__.py", line 1946, in shutdown
    h.close()
  File "/usr/lib64/python3.6/logging/handlers.py", line 894, in close
    self.socket.close()
AttributeError: 'SysLogHandler' object has no attribute 'socket'

result: SocketHandler ==> No output ..我不确定它是否正常工作。

我不确定通过TCP端口将日志发送到syslog服务器的正确方法。我已经使用了syslogHandler和SocketHandler。

syslogHandler: 使用syslogHandler我得到ConnectionRefusedError是因为我的远程服务器无法访问,可能我会用用户try..except方法。。但是我不确定为什么我得到AttributeError: 'SysLogHandler' object has no attribute 'socket'

SocketHandler: Python日志记录模块处理程序页面说该类用于通过TCP将日志发送到远程。但是我看不到任何输出,并且不确定这是否是将日志发送到syslog服务器的正确方法。

请帮助。

提前谢谢。

1 个答案:

答案 0 :(得分:1)

这不是一个适当的解决方案,如果不是绝对必须使用TCP,我建议您使用UDP。它使用syslog处理程序解决了我的很多问题。 TCP似乎想将消息捆绑在一起,具有讽刺意味的是,它在批处理过程中丢失了一些消息。

当我在具有启动并正在监听端口611的syslog服务器的计算机上尝试此操作时,它没有在SysLogHandler上引发AttributeError。所以您可能应该设置服务器以侦听该端口上的问题

相关问题