1 January 2008Logging to syslog in Python
I was trying to use the standard Python
logging
module to write messages to syslog. Thelogging
module has aSysLogHandler
class which can log to a local or remote syslog daemon.With no host specified,
SysLogHandler
useslocalhost
which is what I wanted. I tried to useSysLogHandler,
but it just wouldn’t work. There was no error when I called the logging methods, but my messages didn’t show up in/var/log/syslog
.syslog module works
Python also has a standard
syslog
module. I tried it and it worked fine; my messages were written to the syslog file.For example:
import syslogsyslog.syslog('test')syslogd isn’t listening
After running Wireshark I found the
SysLogHandler
was correctly sending a UDP packet tolocalhost
on port 514. I could also see there was an ICMP response indicating the UDP packet was not received on that port. syslog wasn’t listening!Use /dev/log
Instead of sending to
localhost
, I wantedSysLogHandler
to pass the message to syslog on the local machine in the same way thesyslog
Python module was doing.The solution is to pass
/dev/log
as theaddress
parameter toSysLogHandler
. It’s not , but it works.For example:
import loggingfrom logging.handlers import SysLogHandlerlogger = logging.getLogger()logger.setLevel(logging.INFO)syslog = SysLogHandler(address='/dev/log')formatter = logging.Formatter('%(name)s: %(levelname)s %(message)s')syslog.setFormatter(formatter)logger.addHandler(syslog)Easy when you know how.