为什么Django不再认为mysqldb是有效的后端?

oct*_*bus 3 python apache django mod-wsgi ubuntu-12.04

我在这里问下面的问题,因为它涉及开发人员工具.

我已将Ubuntu 10.04 LTS工作站升级到12.04 LTS(32位).今天我去尝试一个没有错误的Django Web应用程序.它在Apache上运行.

应用程序不再起作用并返回错误.我一直在处理一系列错误/var/log/apache2/error.log.

第一个错误涉及UCS2和UCS4(为了便于阅读而修剪线条).

ImportError: /usr/local/lib/python2.7/lib-dynload/_io.so: 
undefined symbol: PyUnicodeUCS2_FromObject
mod_wsgi (pid=9246): Target WSGI script 
'/usr/local/www/wsgi-scripts/wsgi_amr_handler.py' 
cannot be loaded as Python module.
Run Code Online (Sandbox Code Playgroud)

通过重建和重新安装最新版本的mod_wsgi来解决这个问题.

当前错误涉及mysqldb不是有效的后端.这是错误(为清晰起见,删除了时间戳):

backend = load_backend(db['ENGINE'])
File "/usr/local/lib/python2.7/site-packages/django/db/utils.py", line 51, 
in load_backend
raise ImproperlyConfigured(error_msg)
ImproperlyConfigured: 'mysql' isn't an available database backend.
Try using django.db.backends.mysql instead.
Error was: No module named mysql.base
Run Code Online (Sandbox Code Playgroud)

这是Django应用程序的settings.py中的配置问题还是别的什么?

是否有Python 2.7,mod_wsgi,Django和mysqldb的安装顺序,这可能是问题吗?

这是我当前(收到评论后)settings.py

DATABASES = {
'default': {
'ENGINE': ' django.db.backends.mysql', 
'NAME': 'server',      # Or path to database file if using sqlite3.
'USER': 'ox',          # Not used with sqlite3.
'PASSWORD': 'xxxx',                  # Not used with sqlite3.
'HOST': '',     
'PORT': '',  
    }
}
Run Code Online (Sandbox Code Playgroud)

以下是错误:

ImproperlyConfigured: ' django.db.backends.mysql' isn't an available database backend.
Try using django.db.backends.XXX, where XXX is one of:
'dummy', 'mysql', 'oracle', 'postgresql_psycopg2', 'sqlite3'
Error was: No module named  django.db.backends.mysql.base
Run Code Online (Sandbox Code Playgroud)

Mar*_*ers 5

你显然也升级了你的Django安装.最近的Django版本需要后端模块的名.在1.2版中更改了指定数据库的方式,您需要按照升级说明更新Django项目代码库.

对于MySQL,现在正确的后端django.db.backends.mysql; 打开settings.py并更新您的DATABASES条目.