python - 使用 Pyramid 和 rq 写入同一个日志文件

标签 python multithreading logging pyramid python-multithreading

我正在使用 Pyramid 和 rq我想将 rq worker 作业记录在与我的 Pyramid 应用程序相同的文件中。

我的设置是这样的:

开发.ini

# regular pyramid setup here...

[loggers]
keys = root, main

[handlers]
keys = console, debuglog

[formatters]
keys = generic

[logger_root]
level = DEBUG
handlers = console, debuglog

[logger_main]
level = DEBUG
handlers =
qualname = main

[handler_debuglog]
class = handlers.RotatingFileHandler
args = ('%(here)s/__logs/pyramid_debug.log','a')
level = DEBUG
formatter = generic

[formatter_generic]
format = %(asctime)s %(levelname)-8s [%(name)s][%(threadName)s] %(message)s

主.py

from bunch import Bunch
from redis import Redis
from rq import Queue, Worker
from helpers.rqworker import run_worker
from helpers.log import write_log

write_log('info', 'APP STARTED.')
q = Queue(connection=Redis())
req_obj = Bunch()
req_obj.remote_addr = self.request.remote_addr
job = q.enqueue(run_worker, req_obj, {'some_other': 'data'})
write_log('info', 'APP ENDED.')

helpers/rqworker.py

from helpers.log import write_log

def run_worker(req, data):
    write_log(req, 'debug', 'WORKER STARTED', separator=True)

helpers/log.py

import logging
log = logging.getLogger(__name__)


def write_log(request, loglevel, message=None, **kwargs):
    msg = '[{0}] {1}'.format(request.remote_addr, message)
    level = logging.getLevelName(loglevel.upper())

    if 'separator' in kwargs:
        log.log(level, '='*40)

    if message:
        log.log(level, msg)

    if 'stack' in kwargs:
        log.log(level, '{0} EXCEPTION {0}'.format('*'*15))
        log.log(level, kwargs['stack'])
        log.log(level, '{0} EXCEPTION END {0}'.format('*'*13))

当我运行我的应用程序时,我看不到来自 rqworker.py 的日志(可能是因为它是一个单独的线程)所以我想知道我如何(并且有可能)实现写入到同一个日志文件?

最佳答案

这可能对 OP 不再有用,但我能够将 rq Worker 的输出重定向到自定义文件的方法是通过这样获取记录器:

logger = logging.getLogger('rq.worker')

您可以向此记录器添加一个新的 FileHandler 以在您的文件上输出,并更改格式:

h = logging.FileHandler("/path/to/logfile.log")
formatter = logging.Formatter(...)
fh.setFormatter(formatter)
logger.addHandler(fh)

不过,我无法删除输出的颜色,这会导致在文本编辑器中打开日志时,ANSI 颜色代码略微困惑。

请注意,这会删除控制台的日志记录。您也可以通过添加另一个处理程序来保留它。

关于python - 使用 Pyramid 和 rq 写入同一个日志文件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27620906/

相关文章:

c - 如何将消息(在 C 中)从一个线程发送到另一个线程?

c++ - 如何设置 "this"线程的自定义名称?

c# - 从 C# 中的 EventHandler<T> 确定事件名称

logging - 如何在sql Developer中查看编译器日志?

ruby - 无法写入守护进程中的日志

python - Pandas read_table() 数千 =',' 不工作

Python初学者--如何清理这一段代码

Python 3 - 导入错误 : No module named

python - 无法使用 Python 中的请求加载网站

Java/SQLite - 如何编译 -DTHREADSAFE=1?