- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我在使用 Amazon Linux AMI 的 AWS EC2 上使用 tornado 3.2.1、python 2.7.3、supervisord 3.0。
我正在尝试获取请求级别日志记录(例如“200 POST/(127.0.0.1) 0.75ms”(这是请求级别日志记录的定义,对吧?))以写入日志文件和异常堆栈跟踪记录到另一个日志文件。我从here看到作为 Tornado 的一部分,有三个潜在的日志可用,理想情况下,我还希望从写入另一个文件的一般日志中报告输出。我读过让 supervisord(或 Tornado 以外的东西)处理日志文件的写入更好。
我的 supervisord.conf 看起来像这样:
[unix_http_server]
file=/var/lib/supervisor/supervisor.sock ; (the path to the socket file)
[supervisord]
logfile=/var/log/supervisor/supervisord.log ; (main log file;default $CWD/supervisord.log)
logfile_maxbytes=50MB ; (max main logfile bytes b4 rotation;default 50MB)
logfile_backups=10 ; (num of main logfile rotation backups;default 10)
loglevel=info ; (log level;default info; others: debug,warn,trace)
pidfile=/var/run/supervisord.pid ; (supervisord pidfile;default supervisord.pid)
nodaemon=false ; (start in foreground if true;default false)
minfds=1024 ; (min. avail startup file descriptors;default 1024)
minprocs=200 ; (min. avail process descriptors;default 200)
[rpcinterface:supervisor]
supervisor.rpcinterface_factory = supervisor.rpcinterface:make_main_rpcinterface
[supervisorctl]
serverurl=unix:///var/lib/supervisor/supervisor.sock ; use a unix:// URL for a unix socket
[include]
files=supervisord.d/*.ini
这是我的应用程序 supervisord ini 文件:
[program:myapp]
process_name=myapp%(process_num)s
directory=/opt/me/venvs/myapp
command=/opt/me/venvs/myapp/bin/python /opt/me/venvs/myapp/bin/run_myapp.py --port=%(process_num)s --logging=DEBUG
startsecs=2
user=me
stdout_logfile=/var/log/myapp/access-%(process_num)s.log
stderr_logfile=/var/log/myapp/error-%(process_num)s.log
numprocs=2
numprocs_start=14000
我在 run_myapp.py 的底部有这段代码
if __name__ == "__main__":
tornado.options.define("port", default=7777, help="run on the given port", type=int)
tornado.options.parse_command_line()
http_server = tornado.httpserver.HTTPServer(Application())
http_server.listen(tornado.options.options.port)
tornado.ioloop.IOLoop.instance().start()
似乎发生的是请求级别信息、堆栈跟踪和 logging.info('doing something...')
的使用都被记录到由 supervisord stderr_logfile 变量指定的文件中. stdout_logfile 中没有任何记录。我唯一可以将任何内容记录到 stdout_logfile 的情况是,如果我实际上在代码中放置 print
语句并使用 sys.stdout.flush()
刷新缓冲区(或使用 -u 标志启动 python)。
将请求记录到 stdout_logfile、堆栈跟踪和其他应用程序级输出到 stderr_logfile 的正确方法是什么?我想问题的第二部分已经回答了,因为它已经这样做了,但第一部分到目前为止还没有解决。
最佳答案
Tornado 在 parse_command_line 中的内置日志配置无法帮助您分离日志流 - 您必须设置 tornado.options.options.logging=None 并直接在 python 日志记录模块中管理您自己的配置。
Supervisord 只能处理两个日志文件(stdout 和 stderr),所以你不能让 supervisord 处理你的日志文件并进行细粒度分离,但你可以有两个流。配置 tornado.access 记录器以使用 propagate=False 写入 stdout,并将根记录器配置为写入 stderr。然后你可以在 supervisord 中给两个流不同的输出文件。
关于python - Tornado - 应用程序和请求日志记录如何工作?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/23795350/
根据一些谷歌搜索,我安装了以下错误处理程序。然而,似乎返回 http 500 的 python 异常并没有被这些东西捕获,尽管 404 是这样。通过我在下面的代码中留下的打印语句,我可以看到它没有命中
我刚刚意识到 WebSocketHandler.write_message() 返回一个 Future。我以前没有在我的函数中产生过这个函数: @tornado.gen.coroutine
这是我的 Tornado 文件:: from tornado.wsgi import WSGIContainer from tornado.ioloop import IOLoop from torn
class MainHandler(BaseHandler): @tornado.web.authenticated def get(self): self.rende
我正在尝试使用 AsyncHTTPTestCase 测试 Tornado .我想测试标有 @tornado.web.authenticated 注释的处理程序。因为此处理程序需要身份验证,所以我们必须
我正在使用 Tornado Web Server (版本 4.1)使用 Python 2.7 创建 REST Web 应用程序。我的请求处理程序之一 (web.RequestHandler) 使用多部
我想知道tornado 的内部工作流程,并且看过this article ,很好,但我就是想不通 ioloop.py里面有这样一个函数 def add_handler(self, fd, handle
如何遍历从 Python/Tornado 处理程序传递到 Tornado 模板的字典? 我试过 {% for key, value in statistics %}
我有一个 Tornado 后端,为 Angular 前端提供服务。更新数据库时,tornado api 不会获取更新的数据。它仅在我重新启动服务器后出现。有人可以帮我解决这个问题吗?我希望获取的数据能
我尝试使用自定义的 WSGIContainer 来处理异步操作: from tornado import httpserver, httpclient, ioloop, wsgi, gen @gen.
from tornado.web import RequestHandler class HelloWorldHandler(RequestHandler): def get(self):
Pylint 遇到 @tornado.web.authenticated 时崩溃 class Handler1(tornado.web.RequestHandler): def get(sel
经过 tornado.gen documentation有人可以帮我理解 tornado.gen.coroutine 和 tornado.gen.engine 之间的确切区别 最佳答案 正如 gen.
代码如下: from tornadoredis import Client from tornado.ioloop import IOLoop from tornado.gen import coro
我有一个 tornado.websocket.WebSocketHandler 的子类。在该类中,我有一个方法使用 Django ORM 从子类模型中获取用户:django.contrib.auth.
我是 ssl 之类的新手,我已经使用 openssl 生成了自签名证书。 openssl req -newkey rsa:2048 -nodes -keyout key.pem -x509 -days
我已经从 tornado 4.2 移动到 tornado 6.0.3,我得到了错误 AttributeError:模块“tornado.web”没有属性“异步” 根据 tornado v6 seems
我一直在关注此 ( https://developer.ibm.com/tutorials/se-distributed-apps-zeromq-part2/) 教程,以设置使用 CurveZMQ 加
我在使用tornado-celery整合tornado和celery时,出现错误:``` traceback (most recent call last): File "/usr/local/l
我正在使用 Tornado 与 twitter 等第三方进行身份验证。 我的登录处理程序看起来像这样 class AuthLoginHandler(BaseHandler, tornado.auth.
我是一名优秀的程序员,十分优秀!