【问题标题】:ImproperlyConfigured: Error loading MySQLdb module: No module named MySQLdb -- Django 1.4 & Google App Engine配置不当:加载 MySQLdb 模块时出错:没有名为 MySQLdb 的模块——Django 1.4 和 Google App Engine
【发布时间】:2016-12-19 23:36:59
【问题描述】:

这将是我一生中第二次发布几乎完全相同的内容。这次和上次相差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 中的“库”部分

-在运行时检查 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')

这样做,当我寻找“发现:假”时,我没有找到它。我发现“找到:真”应该告诉我找到 MySQLdb 模块没有任何问题。但是,当它到达import MySQLdb 行时,程序会因ImportError: No module named MySQLdb 而崩溃,并且永远不会到达print('Import success')

发生了什么事?

编辑:我现在将尝试在我的 Linux 分区上执行此操作,但我认为我在那里所做的任何事情都不会帮助我弄清楚在 Mac OS 上该怎么做

【问题讨论】:

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


    【解决方案1】:

    经过几个小时的挖掘,我终于找到了根本问题。从 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 目录中。作为快速修复,我通过运行以下命令创建了一个符号链接(顺便说一句):

    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 能够正常加载;我的应用程序初始化并成功运行了很长时间。

    【讨论】:

      猜你喜欢
      • 2018-12-05
      • 1970-01-01
      • 2012-09-28
      • 2020-06-08
      • 2015-08-22
      • 2017-01-27
      • 2014-11-12
      • 2017-04-22
      • 2013-02-25
      相关资源
      最近更新 更多