数据库
首页 > 数据库> > python – 为什么Django不再认为mysqldb是一个有效的后端?

python – 为什么Django不再认为mysqldb是一个有效的后端?

作者:互联网

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

我已将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.

通过重建和重新安装最新版本的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

这是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': '',  
    }
}

以下是错误:

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

解决方法:

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

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

标签:python,django,apache,mod-wsgi,ubuntu-12-04
来源: https://codeday.me/bug/20190901/1783894.html