配置不正确:加载MySQLdb模块时出错:没有名为MySQLdb的模块 - Django 1.4& Google App Engine

时间:2016-08-12 21:29:47

标签: python mysql django google-app-engine mysql-python

这将是我生命中第二次发布几乎完全相同的事情。这个时间和上次之间的差异大约是9个月,很多困难的学习,以及过去9个月我从未遇到过这个问题并且在整个时间段内经常使用MySQLdb的事实。我认识到有很多次问过类似的问题。我已阅读回复并执行了建议的修复程序。到目前为止,我仍然无法取得圆满成功,这就是我发布问题的原因。

仅描述我的环境:我正在使用Google App Engine Launcher在Google App Engine上运行Django应用。我正在使用Mac OS X El Capitan。

当这些应用程序部署在Google App Engine上时,它们可以按预期完美运行。但是,在本地运行时,我会在尝试运行应用程序时始终获得ImportError。

让我列出一些我已经检查过和/或试图解决问题的事情:

- 安装了mysql

- 安装了mysql-python

- 将MySQLdb添加到app.yaml中的“Libraries”部分

- 在运行时检查PYTHONPATH以确认正确的目录被添加到路径。

- 在导入之前添加路径作为虚拟检查

- 更新了Google App Engine SDK

我已经完成了更多,但现在几乎无法回忆起它们。在运行时检查路径时,我可以清楚地看到MySQLdb所在的google_appengine SDK目录的以下路径:

/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上做什么

1 个答案:

答案 0 :(得分:0)

经过几个小时的挖掘后,我终于发现了根本问题。从MySQLdb正常工作以及MySQLdb停止正常工作的时间开始的唯一重大变化是我将OS X升级到El Capitan。

运行:

otool -L /Library/Python/2.7/site-packages/_mysql.so

显示_mysql.so正在libmysqlclient.18.dylib目录中搜索/usr/lib,当它真正位于/usr/local/lib目录中时。作为一个快速解决方案,我通过运行以下命令创建了一个符号链接(全部在一行btw):

sudo ln -s /usr/local/mysql/lib/libmysqlclient.18.d‌​ylib /usr/local/lib/libmysqlclient.18.dylib

由于El Capitan实施了Apple的“无根”模式,并且当前用户(我)无法写入/usr/lib,因此在/usr/local/lib中创建符号链接就足够了,对Mac用户来说可能更好

执行这些步骤后,MySQLdb能够正确加载;我的应用程序初始化并在很长一段时间内第一次成功运行。