使用nginx,uwsgi,flask进行简单的应用程序记录/调试?

Mit*_*ops 26 python logging nginx flask uwsgi

我不打算打开危险的调试控制台,但是我的应用程序出现了500错误,并且似乎没有为我编写任何输出以进行更深入的调查.

在邮件列表上看到了这个交换,这使我进入了关于日志记录错误的页面.

但是,我仍然觉得这很令人困惑,并且有几个问题:

(1)下面的内容应该在哪个文件中?

ADMINS = ['yourname@example.com']
if not app.debug:
    import logging
    from logging.handlers import SMTPHandler
    mail_handler = SMTPHandler('127.0.0.1',
                               'server-error@example.com',
                               ADMINS, 'YourApplication Failed')
    mail_handler.setLevel(logging.ERROR)
    app.logger.addHandler(mail_handler)
Run Code Online (Sandbox Code Playgroud)

...假设大型应用程序的"越来越大"的文件模式? __init__.pyconfig.pyrun.py

(2)我被那里的选择所震撼,无法分辨我应该使用哪些.我应该打开哪些记录器,使用什么设置来复制本地python服务器调试,当我运行run.py时,我得到stdout?我发现默认的本地输出流非常有用,比页面中的交互式调试器更有用.有没有人有一个模式,他们可以分享设置复制这个与nginx部署,输出到日志?

(3)有什么我需要改变的,不是在烧瓶级别,而是在nginx中,比如在我的/etc/nginx/sites-available/appname文件中,以启用日志记录?

UPDATE

具体来说,我正在寻找信息,就像我在本地运行python时获得的信息,例如,为什么包没有工作,或者我的语法错误可能是什么,或者什么变量不存在:

$ python run.py 
Traceback (most recent call last):
  File "run.py", line 1, in <module>
    from myappname import app
  File "/home/me/myappname/myappname/__init__.py", line 27, in <module>
    file_handler.setLevel(logging.debug)
  File "/usr/lib/python2.7/logging/__init__.py", line 710, in setLevel
    self.level = _checkLevel(level)
  File "/usr/lib/python2.7/logging/__init__.py", line 190, in _checkLevel
    raise TypeError("Level not an integer or a valid string: %r" % level)
Run Code Online (Sandbox Code Playgroud)

当我在服务器上运行flask时,我从未见过这个.我刚刚在浏览器中收到uWSGI错误,并且不知道哪个代码有问题.我想像上面这样的东西写入文件.

我还注意到,设置以下日志记录并没有真正写入文件,即使我将日志方式转到DEBUG级别:

from logging import FileHandler
file_handler = FileHandler('mylog.log')
file_handler.setLevel(logging.DEBUG)
app.logger.addHandler(file_handler)
Run Code Online (Sandbox Code Playgroud)

mylog.log 是空白,即使我的应用程序出错了.

我还要补充一点,我试图通过以下方式设置debug = True __init__.py:

app = Flask(__name__)
app.debug = True
app.config['DEBUG'] = True
from werkzeug.debug import DebuggedApplication
app.wsgi_app = DebuggedApplication(app.wsgi_app, True)
app.config.from_object('config')
app.config.update(DEBUG=True)
app.config['DEBUG'] = True
if __name__ == '__main__':
    app.run(debug=True)
Run Code Online (Sandbox Code Playgroud)

在我的config.py文件中,我有......

debug = True
Debug = True
DEBUG = True
Run Code Online (Sandbox Code Playgroud)

然而,没有调试发生,没有记录或调试,这很难追查.错误只是使用无用的浏览器消息终止应用程序:

uWSGI Error
Python application not found
Run Code Online (Sandbox Code Playgroud)

pla*_*aes 7

设置config['PROPAGATE_EXCEPTIONS']True在生产中运行应用程序时,您希望将回溯记录到日志文件中.(我没有尝试使用SMTP处理程序,但..)


Vin*_*jip 2

  1. 您创建处理程序、添加到记录器等的部分应该位于if __name__ == '__main__'子句中,即您的主入口点。我想那会是run.py
  2. 我不确定我能回答这个问题——这取决于你想要什么。我建议查看日志教程以查看可用的各种选项。
  3. 我不认为你需要在这个nginx层面上改变任何东西。

更新:您可能希望有一个涵盖未捕获异常的异常子句,例如

if __name__ == '__main__':
    try:
        app.run(debug=True)
    except Exception:
        app.logger.exception('Failed')
Run Code Online (Sandbox Code Playgroud)

它应该将发生的任何异常的回溯写入app.run()日志。