当前位置: 首页 > 面试题库 >

将所有错误记录到Django站点上的控制台或文件中

范稳
2023-03-14
问题内容

在调试模式下运行runserver时,如何获取Django 1.0将 所有 错误写入控制台或日志文件?

我已经尝试使用具有process_exception函数的中间件类,如对此问题的可接受答案所述:

如何在Django网站上记录服务器错误

对于某些异常,将调用process_exception函数(例如:views.py中的assert(False)),但对于诸如ImportErrors之类的其他错误,将不会调用process_exception(例如,在urs.py中导入thisclassdoesnotexist)。我是Django
/ Python的新手。这是因为运行时错误和编译时错误之间有区别吗?但是然后我希望runserver抱怨它是否是编译时错误,而不是。

我已经看过西蒙·威利森(Simon
Willison)关于Django调试的精彩演讲(html" target="_blank">http://simonwillison.net/2008/May/22/debugging/),但是我没有找到适合我的选项。

如果相关的话,我正在写一个Facebook应用程序,Facebook用自己的消息掩盖HTTP
500错误,而不是显示Django的内容丰富的500页。因此,我需要一种将 所有 类型的错误写入控制台或文件的方法。

编辑:
我想我的期望是,如果urls.py中的导入错误(ImportError)时,如果Django可以返回500个错误页面,其中包含大量详细信息,则它应该能够将相同的详细信息写入控制台或文件而无需必须在代码中添加任何其他异常处理。我从未见过关于import语句的异常处理。

谢谢杰夫


问题答案:

这有点极端,但是出于调试目的,您可以打开该DEBUG_PROPAGATE_EXCEPTIONS设置。这将允许您设置自己的错误处理。设置上述错误处理的最简单方法是覆盖sys.excepthook。这将终止您的应用程序,但是它将起作用。您可能需要做一些事情,以确保它不会杀死您的应用程序,但这取决于您要为其部署此平台的平台。无论如何,绝对不要在生产中使用它!

对于生产来说,几乎必须要有大量的错误处理。我使用的一种技术是这样的:

>>> def log_error(func):
...     def _call_func(*args, **argd):
...         try:
...             func(*args, **argd)
...         except:
...             print "error" #substitute your own error handling
...     return _call_func
...
>>> @log_error
... def foo(a):
...     raise AttributeError
...
>>> foo(1)
error

如果在视图上使用log_error作为装饰器,它将自动处理其中发生的任何错误。

流程_异常函数针对某些异常(例如,views.py中的assert(False))_被调用,但流程异常并未针对诸如ImportErrors(例如:在urs.py中导入thisclassdoesnotexist)之类的其他错误而被调用。我是Django
/ Python的新手。这是因为运行时错误和编译时错误之间有区别吗?

在Python中,所有错误均为运行时错误。造成问题的原因是因为在调用视图之前导入模块时,这些错误会立即发生。我发布的第一种方法将捕获此类错误以进行调试。您可能可以为生产找到一些解决方案,但是我认为如果在生产应用程序中遇到ImportErrors(并且没有进行任何动态导入),则问题会更严重。

不过,像pylint这样的工具可以帮助您消除此类问题。



 类似资料:
  • 我想将gradle脚本中的所有控制台输出记录到日志文件中: 但是我的gradle脚本提示用户参数: 因此,我有一个NullPointerException: 有人知道这种情况的解决方案或变通方法吗?

  • 我正在迁移一个遗留的应用程序来使用logback,在这个过程中我试图保持所有的旧功能以相同的方式工作。遗留应用程序所做的一件事是,如果无法写入日志文件(由于空间不足、权限不正确等原因),则将日志记录到控制台 对于logback,似乎应该由StatusListener来处理这个问题,我可以使用getOrigin获得筛选后的附加程序,但我不知道如何获得与origin附加程序相关联的日志记录程序。有可能

  • 问题内容: 我可以将所有消息定向到log.txt文件: 但是我也如何在控制台中获取日志消息? 问题答案: 使用 MultiWriter创建一个写入器,该写入器将其写入复制到所有提供的写入器中,类似于Unix tee(1)命令

  • 我已经创建了一个对我来说很好的Webpack构建——它有一个用于热重新加载的dev服务器,还有一个运行模板html文件并集成文件。 这一切都很好,但当我在我的开发服务器上工作时,控制台会给我如下错误消息: 它引用了是错误的来源,而不是我正在使用的组件,这使得很难追踪错误的来源。 据控制台所知,我知道它是包含错误的文件,但如何让控制台记录预绑定代码?(例如,) 提前感谢。

  • 问题内容: 写入控制台,您得到 但是,看起来配置文件也已找到并且无法解析: 问题答案: 我已经处理了一段时间了。我已经按照本文中所述更改了所有内容,甚至认为发生了错误。在这种情况下,请确保在更改.xml或.properties文件中的设置时清理项目。在日食环境中。选择项目->清洁

  • 写到控制台,你得到 但是,它也看起来像配置文件已经找到,并且不可解析: