Django1.7 'RemovedInDjango19Warning' 将 apache 与 mod_wsgi 一起使用时

Django1.7 'RemovedInDjango19Warning' when using apache with mod_wsgi

我正在为应用程序使用 Django 1.7 版, 在我的开发 PC 中,一切都 运行 很好(我使用 manage.py runserver 命令运行它。

现在我正在尝试将其移至生产服务器。 在生产服务器中,当 运行 服务器使用 manage.py 命令时,一切仍然很好。

但是远程访问应用程序(通过 apache2 和 mod_wsgi),我得到一个 RemovedInDjango19Warning 异常。

在寻找解决方案后,我只能找到如何忽略 manage.py 的这些警告,这些警告对我不起作用,我不知道如何禁用 wsgi 的警告?

回溯:

Environment:


Request Method: GET
Request URL: http://192.168.0.17/

Django Version: 1.7.1
Python Version: 3.4.3
Installed Applications:
('django.contrib.admin',
 'django.contrib.auth',
 'django.contrib.contenttypes',
 'django.contrib.sessions',
 'django.contrib.messages',
 'django.contrib.staticfiles',
 'django_extensions',
 'rest_framework',
 'rest_framework_nested',
 'django_gravatar',
 'authentication',
 'djcelery',
 'job',
 'seed',
 'proxies',
 'emails')
Installed Middleware:
('django.contrib.sessions.middleware.SessionMiddleware',
 'django.middleware.common.CommonMiddleware',
 'django.middleware.csrf.CsrfViewMiddleware',
 'django.contrib.auth.middleware.AuthenticationMiddleware',
 'django.contrib.auth.middleware.SessionAuthenticationMiddleware',
 'django.contrib.messages.middleware.MessageMiddleware',
 'django.middleware.clickjacking.XFrameOptionsMiddleware')


Traceback:
File "/usr/local/lib/python3.4/dist-packages/django/core/handlers/base.py" in get_response
  98.                 resolver_match = resolver.resolve(request.path_info)
File "/usr/local/lib/python3.4/dist-packages/django/core/urlresolvers.py" in resolve
  343.             for pattern in self.url_patterns:
File "/usr/local/lib/python3.4/dist-packages/django/core/urlresolvers.py" in url_patterns
  372.         patterns = getattr(self.urlconf_module, "urlpatterns", self.urlconf_module)
File "/usr/local/lib/python3.4/dist-packages/django/core/urlresolvers.py" in urlconf_module
  366.             self._urlconf_module = import_module(self.urlconf_name)
File "/usr/lib/python3.4/importlib/__init__.py" in import_module
  109.     return _bootstrap._gcd_import(name[level:], package, level)
File "/var/www/cvc.ma/CapValue/urls.py" in <module>
  6.                        url(r'^api/v1/auth/', include('authentication.urls')),
File "/usr/local/lib/python3.4/dist-packages/django/conf/urls/__init__.py" in include
  28.         urlconf_module = import_module(urlconf_module)
File "/usr/lib/python3.4/importlib/__init__.py" in import_module
  109.     return _bootstrap._gcd_import(name[level:], package, level)
File "/var/www/cvc.ma/authentication/urls.py" in <module>
  2. from authentication.views import LoginView, LogoutView
File "/var/www/cvc.ma/authentication/views.py" in <module>
  4. from rest_framework import permissions, viewsets, status, views
File "/usr/local/lib/python3.4/dist-packages/rest_framework/viewsets.py" in <module>
  24. from rest_framework import views, generics, mixins
File "/usr/local/lib/python3.4/dist-packages/rest_framework/views.py" in <module>
  11. from rest_framework.request import Request
File "/usr/local/lib/python3.4/dist-packages/rest_framework/request.py" in <module>
  20. from rest_framework.settings import api_settings
File "/usr/local/lib/python3.4/dist-packages/rest_framework/settings.py" in <module>
  22. from django.utils import importlib, six
File "/usr/local/lib/python3.4/dist-packages/django/utils/importlib.py" in <module>
  10.     RemovedInDjango19Warning, stacklevel=2)

Exception Type: RemovedInDjango19Warning at /
Exception Value: django.utils.importlib will be removed in Django 1.9.

这是因为 Django 1.9 中删除了 django.utils.importlib 模块,取而代之的是标准库中的 importlib。 Django Rest Framework 仍在使用它。

您可以按照此问题已接受答案的说明禁用警告 --

如果你只想让 mod_wsgi 中的警告静音,你可以添加一个配置指令,例如:

WSGIPythonWarnings ignore::DeprecationWarning::

this blog entry, the release notes (point 15) and the original issue

本质上,mod_wsgi 没有等同于 -W 控制选项,因此添加了一个指令。默认值必须保持在 "log everything" 以在不同的 wsgi 应用程序之间保持一致。

最后,我升级到 Django1.9 并修复了迁移错误。