Django:无法配置处理程序"syslog"



我从django项目制作Docker镜像,它开始产生我以前从未有过的错误。该错误似乎与日志记录有关,特别是系统日志。起初,我认为 docker 映像中缺少/dev/log会产生错误。所以我在 docker 文件中添加了行以创建/dev/文件夹和log文件。但是,错误并没有消失。

这是错误日志。

File "/usr/local/lib/python2.7/site-packages/django/utils/autoreload.py", line 228, in wrapper
fn(*args, **kwargs)
File "/usr/local/lib/python2.7/site-packages/django/core/management/commands/runserver.py", line 116, in inner_run
autoreload.raise_last_exception()
File "/usr/local/lib/python2.7/site-packages/django/utils/autoreload.py", line 251, in raise_last_exception
six.reraise(*_exception)
File "/usr/local/lib/python2.7/site-packages/django/utils/autoreload.py", line 228, in wrapper
fn(*args, **kwargs)
File "/usr/local/lib/python2.7/site-packages/django/__init__.py", line 22, in setup
configure_logging(settings.LOGGING_CONFIG, settings.LOGGING)
File "/usr/local/lib/python2.7/site-packages/django/utils/log.py", line 75, in configure_logging
logging_config_func(logging_settings)
File "/usr/local/lib/python2.7/logging/config.py", line 794, in dictConfig
dictConfigClass(config).configure()
File "/usr/local/lib/python2.7/logging/config.py", line 576, in configure
'%r: %s' % (name, e))
ValueError: Unable to configure handler 'syslog': [Errno 2] No such file or directory

这是日志记录相关设置。

LOGGING = {
'version': 1,
'disable_existing_loggers': False,
'handlers': {
'mail_admins': {
'level': 'ERROR',
'class': 'django.utils.log.AdminEmailHandler'
},
'syslog': {
'level': 'DEBUG',
'class': 'logging.handlers.SysLogHandler',
'facility': 'user',
'address': '/dev/log',
},
'null': {
'level': 'DEBUG',
'class': 'logging.NullHandler',
},
'stream': {
'level': 'INFO',
'class': 'logging.StreamHandler'
},
},
'loggers': {
'root': {
'handlers': ['syslog', 'mail_admins'],
'level': 'ERROR',
},
'SocialAuth': {
'handlers': ['mail_admins'],
'level': 'WARN',
},
'django': {
'handlers': ['syslog', 'mail_admins'],
'level': 'ERROR',
},
}

我创建了文件夹和路径/dev/log,但似乎这不是问题。

第一个问题是文件系统中没有/dev/log(/dev通常挂载为tmpfs,而不是驱动器支持的FS(。

下一个问题是SysLogHandler(logging.handlers.SysLogHandler(要求address是UNIX域套接字,而不是其他任何东西。所以,你需要创建一个UNIX套接字/dev/log,并在DjangoSysLogHandler中传递地址。


您可以通过nc(netcat( 创建 UNIX 域 sokcet ,如果您的版本支持-U选项:

nc -lU /dev/log

或者你可以直接在Python中创建套接字创建,将地址族提及为AF_UNIX

import sokcet
sock = socket.socket(socket.AF_UNIX)
sock.bind('/dev/log')

在创建容器时,上述任何一项都可以作为Dockerfile/docker-compose.yml中的命令。

最新更新