3

我正在 Google App Engine 上创建一个应用程序。我正在使用 Django 1.4 和 Python 2.7。在本地主机上一切正常。但是在部署后它没有运行,我一直在管理日志上得到这个:

    2012-12-15 15:02:41.870

    /base/python27_runtime/python27_lib/versions/1/lib/cacerts/urlfetch_cacerts.txt missing; without this urlfetch will not be able to validate SSL certificates.

    W 2012-12-15 15:02:41.870

    No ssl package found. urlfetch will not be able to validate SSL certificates.

    E 2012-12-15 15:02:46.086

    Traceback (most recent call last):
      File "/base/python27_runtime/python27_lib/versions/1/google/appengine/runtime/wsgi.py", line 196, in Handle
        handler = _config_handle.add_wsgi_middleware(self._LoadHandler())
      File "/base/python27_runtime/python27_lib/versions/1/google/appengine/runtime/wsgi.py", line 266, in _LoadHandler
        __import__(cumulative_path)
      File "/base/data/home/apps/s~cloudwallforever/1.363864476397206865/djangoappengine/main/__init__.py", line 28, in <module>
        setup_env()
      File "/base/data/home/apps/s~cloudwallforever/1.363864476397206865/djangoappengine/boot.py", line 82, in setup_env
        setup_logging()
      File "/base/data/home/apps/s~cloudwallforever/1.363864476397206865/djangoappengine/boot.py", line 130, in setup_logging
        if not settings.DEBUG:
      File "/base/data/home/apps/s~cloudwallforever/1.363864476397206865/django/utils/functional.py", line 276, in __getattr__
        self._setup()
      File "/base/data/home/apps/s~cloudwallforever/1.363864476397206865/django/conf/__init__.py", line 42, in _setup
        self._wrapped = Settings(settings_module)
      File "/base/data/home/apps/s~cloudwallforever/1.363864476397206865/django/conf/__init__.py", line 87, in __init__
        mod = importlib.import_module(self.SETTINGS_MODULE)
      File "/base/data/home/apps/s~cloudwallforever/1.363864476397206865/django/utils/importlib.py", line 35, in import_module
        __import__(name)
      File "/base/data/home/apps/s~cloudwallforever/1.363864476397206865/settings.py", line 6, in <module>
        import django.db.backends.mysql.base
      File "/base/data/home/apps/s~cloudwallforever/1.363864476397206865/django/db/backends/mysql/base.py", line 14, in <module>
        raise ImproperlyConfigured("Error loading MySQLdb module: %s" % e)
    ImproperlyConfigured: Error loading MySQLdb module: No module named MySQLdb

任何想法为什么会发生?

4

3 回答 3

7

'Django Support' 文档提示了解决方案,但没有明确说明:

由于标准的 django.db.backends.mysql 后端在内部使用 MySQLdb,因此 app.yaml 必须在库列表中引用 MySQLdb。

添加以下内容app.yaml似乎可以修复 ImportError:

libraries:
- name: MySQLdb
  version: "latest"

请注意,MySQLdb 当前未包含在可用的第三方库列表中。我一时兴起尝试了它,它似乎已经为我解决了这个问题,YMMV。在此处输入链接描述

于 2013-10-10T21:19:47.113 回答
2

正如Cloud SQL 文档明确指出的那样,您应该将其''google.appengine.ext.django.backends.rdbms'用作数据库引擎设置。

于 2012-12-15T13:47:13.757 回答
0

如果将以下内容添加到您的 app.yaml 后仍无法正常工作:

libraries:
- name: MySQLdb
  version: "latest"

...然后采取以下步骤:

  1. 确保 MySQLdb 已安装pip install mysql-python在 Mac 上
  2. 确保 GAE 开发服务器指向您的 virtualenv/pip'd python 2.7 安装与 Mac/*nix 的默认版本,因为 pip 可能没有在那里安装它。我Can't find module: MySQLdb通过更新 GAE 开发服务器来解决:/usr/local/bin/python2.7例如在Python 路径的 GAE 开发服务器首选项中

注意:可以通过应用程序菜单访问首选项:

  • 如果您使用的是 Windows:请查看下方File > Preferences...
  • 如果您使用的是 Mac,请查看下方GoogleAppengineLauncher > Preferences...
于 2016-02-09T01:46:22.373 回答