配置不当:加载 MySQLdb 模块时出错:没有名为 MySQLdb 的模块——Django 1.4 & Google App Engine
ImproperlyConfigured: Error loading MySQLdb module: No module named MySQLdb -- Django 1.4 & Google App Engine
这将是我一生中第二次发布几乎完全相同的内容。这次和上次的区别大约是 9 个月,很多困难的学习,而且在过去的 9 个月里我从来没有遇到过这个问题,并且在整个时间段内经常完美地使用 MySQLdb。我认识到与此类似的问题已经被问过很多次了。我已阅读回复并执行了建议的修复。到目前为止,我仍然无法得出圆满的结论,这就是我发布问题的原因。
只是为了描述我的环境:我正在 运行使用 Google App Engine 启动器在本地 Google App Engine 上安装 Django 应用程序。我正在使用 Mac OS X El Capitan。
当这些应用程序部署在 Google App Engine 上时,它们可以按预期完美运行。但是,在本地 运行ning 时,我会在尝试 运行 应用程序时始终收到 ImportError。
让我列出一些我检查过的东西 and/or 试图解决问题:
-已安装 mysql
-已安装mysql-python
-将 MySQLdb 添加到 app.yaml
中的 "Libraries" 部分
-在 运行 时检查 PYTHONPATH 以确认正确的目录已添加到路径中。
-导入前添加路径作为虚拟检查
-更新了 Google App Engine SDK
我做了更多,但现在几乎想不起来了。在运行时查看路径时,可以清楚地看到MySQLdb所在的google_appengineSDK目录的路径如下:
/Applications/GoogleAppEngineLauncher.app/Contents/Resources/GoogleAppEngine-default.bundle/Contents/Resources/google_appengine/lib/MySQLdb-1.2.5
这不是我应该看到的吗?我应该指向别的东西吗?我还指出了我安装了其他 python 软件包的其他目录(例如 /Library/Python/2.7/site-packages/)。我错过了什么?我知道我在做一些愚蠢的事情,我对此很好。我只想停止浪费自己的时间来解决这样一个愚蠢的问题。我在其他项目中每天都使用MySQL,从来没有遇到过这样的问题。我现在真的不知道它是什么。
如果我可以添加更多有用的信息,请告诉我,我将很乐意提供帮助。我会把我的一些文件放在下面,希望它们有用。
app.yaml:
application: *omitted*
version: 1
runtime: python27
api_version: 1
threadsafe: true
env_variables:
DJANGO_SETTINGS_MODULE: 'Freya.settings'
handlers:
- url: /favicon\.ico
static_files: static/images/favicon.ico
upload: static/images/favicon\.ico
- url: /static
static_dir: static
application_readable: true
- url: /.*
script: main.app
libraries:
- name: django
version: "latest"
- name: MySQLdb
version: "latest"
main.py:
from google.appengine.ext.webapp import util
import django.dispatch.dispatcher
import django.core.handlers.wsgi
from django.conf import settings
import django.core.signals
import django.db
import os
settings._target = None
app = django.core.handlers.wsgi.WSGIHandler()
def main():
util.run_wsgi_app(app)
if __name__ == '__main__':
main()
settings.py(数据库位):
'default': {
'ENGINE': 'django.db.backends.mysql',
'HOST': '*omitted*',
'NAME': '*omitted*',
'USER': '*omitted*',
}
非常感谢任何帮助。
这是我在 settings.py 中尝试过的示例:
import imp
import sys
import os
print('Checking')
try:
imp.find_module('MySQLdb')
found = True
except ImportError:
found = False
print('Found: ' + str(found))
import MySQLdb
print('Import success')
这样做,当我寻找 'Found: false' 我没有找到它。我发现 'Found: true' 应该真正告诉我找到 MySQLdb 模块没有任何问题。但是,当它到达 import MySQLdb
行时,程序崩溃并显示 ImportError: No module named MySQLdb
并且永远不会到达 print('Import success')
行
怎么回事?
编辑:我现在将尝试在我的 Linux 分区上执行此操作,但我认为我在那里所做的任何事情都不会帮助我弄清楚在 Mac 上该做什么] OS
经过数小时的深入研究,我终于找到了根本问题。从 MySQLdb 正常工作到 MySQLdb 停止正常工作的时间发生的唯一重大变化是我将 OS X 升级到 El Capitan。
运行:
otool -L /Library/Python/2.7/site-packages/_mysql.so
显示 _mysql.so
在 /usr/lib
目录中搜索 libmysqlclient.18.dylib
,而实际上它位于 /usr/local/lib
目录中。作为快速修复,我通过 运行 创建了一个符号 link 以下内容(顺便说一句,全部在一行中):
sudo ln -s /usr/local/mysql/lib/libmysqlclient.18.dylib /usr/local/lib/libmysqlclient.18.dylib
由于 El Capitan 实现了 Apple 的 "rootless" 模式,而当前用户(我)无法写入 /usr/lib
,因此在 /usr/local/lib
中创建了 symlink对于 Mac 用户来说已经足够而且可能更好。
执行这些步骤后,MySQLdb 能够正常加载;我的应用程序已初始化并且 运行 很长一段时间以来第一次成功。
这将是我一生中第二次发布几乎完全相同的内容。这次和上次的区别大约是 9 个月,很多困难的学习,而且在过去的 9 个月里我从来没有遇到过这个问题,并且在整个时间段内经常完美地使用 MySQLdb。我认识到与此类似的问题已经被问过很多次了。我已阅读回复并执行了建议的修复。到目前为止,我仍然无法得出圆满的结论,这就是我发布问题的原因。
只是为了描述我的环境:我正在 运行使用 Google App Engine 启动器在本地 Google App Engine 上安装 Django 应用程序。我正在使用 Mac OS X El Capitan。
当这些应用程序部署在 Google App Engine 上时,它们可以按预期完美运行。但是,在本地 运行ning 时,我会在尝试 运行 应用程序时始终收到 ImportError。
让我列出一些我检查过的东西 and/or 试图解决问题:
-已安装 mysql
-已安装mysql-python
-将 MySQLdb 添加到 app.yaml
中的 "Libraries" 部分-在 运行 时检查 PYTHONPATH 以确认正确的目录已添加到路径中。
-导入前添加路径作为虚拟检查
-更新了 Google App Engine SDK
我做了更多,但现在几乎想不起来了。在运行时查看路径时,可以清楚地看到MySQLdb所在的google_appengineSDK目录的路径如下:
/Applications/GoogleAppEngineLauncher.app/Contents/Resources/GoogleAppEngine-default.bundle/Contents/Resources/google_appengine/lib/MySQLdb-1.2.5
这不是我应该看到的吗?我应该指向别的东西吗?我还指出了我安装了其他 python 软件包的其他目录(例如 /Library/Python/2.7/site-packages/)。我错过了什么?我知道我在做一些愚蠢的事情,我对此很好。我只想停止浪费自己的时间来解决这样一个愚蠢的问题。我在其他项目中每天都使用MySQL,从来没有遇到过这样的问题。我现在真的不知道它是什么。
如果我可以添加更多有用的信息,请告诉我,我将很乐意提供帮助。我会把我的一些文件放在下面,希望它们有用。
app.yaml:
application: *omitted*
version: 1
runtime: python27
api_version: 1
threadsafe: true
env_variables:
DJANGO_SETTINGS_MODULE: 'Freya.settings'
handlers:
- url: /favicon\.ico
static_files: static/images/favicon.ico
upload: static/images/favicon\.ico
- url: /static
static_dir: static
application_readable: true
- url: /.*
script: main.app
libraries:
- name: django
version: "latest"
- name: MySQLdb
version: "latest"
main.py:
from google.appengine.ext.webapp import util
import django.dispatch.dispatcher
import django.core.handlers.wsgi
from django.conf import settings
import django.core.signals
import django.db
import os
settings._target = None
app = django.core.handlers.wsgi.WSGIHandler()
def main():
util.run_wsgi_app(app)
if __name__ == '__main__':
main()
settings.py(数据库位):
'default': {
'ENGINE': 'django.db.backends.mysql',
'HOST': '*omitted*',
'NAME': '*omitted*',
'USER': '*omitted*',
}
非常感谢任何帮助。
这是我在 settings.py 中尝试过的示例:
import imp
import sys
import os
print('Checking')
try:
imp.find_module('MySQLdb')
found = True
except ImportError:
found = False
print('Found: ' + str(found))
import MySQLdb
print('Import success')
这样做,当我寻找 'Found: false' 我没有找到它。我发现 'Found: true' 应该真正告诉我找到 MySQLdb 模块没有任何问题。但是,当它到达 import MySQLdb
行时,程序崩溃并显示 ImportError: No module named MySQLdb
并且永远不会到达 print('Import success')
行
怎么回事?
编辑:我现在将尝试在我的 Linux 分区上执行此操作,但我认为我在那里所做的任何事情都不会帮助我弄清楚在 Mac 上该做什么] OS
经过数小时的深入研究,我终于找到了根本问题。从 MySQLdb 正常工作到 MySQLdb 停止正常工作的时间发生的唯一重大变化是我将 OS X 升级到 El Capitan。
运行:
otool -L /Library/Python/2.7/site-packages/_mysql.so
显示 _mysql.so
在 /usr/lib
目录中搜索 libmysqlclient.18.dylib
,而实际上它位于 /usr/local/lib
目录中。作为快速修复,我通过 运行 创建了一个符号 link 以下内容(顺便说一句,全部在一行中):
sudo ln -s /usr/local/mysql/lib/libmysqlclient.18.dylib /usr/local/lib/libmysqlclient.18.dylib
由于 El Capitan 实现了 Apple 的 "rootless" 模式,而当前用户(我)无法写入 /usr/lib
,因此在 /usr/local/lib
中创建了 symlink对于 Mac 用户来说已经足够而且可能更好。
执行这些步骤后,MySQLdb 能够正常加载;我的应用程序已初始化并且 运行 很长一段时间以来第一次成功。