3

我正在尝试在 Python 2.7 上的 Google App Engine 1.7.4 上的 Django 1.4 上获得 sqlite3 支持。

我摆弄了“Google Cloud SQL”数据库后端,一切都运行良好(syncdb、插入/更新/删除,...)。

但是后来我启用了 sqlite(因为在本地主机上 Google Cloud SQL 很慢):

import os
if (os.getenv('SERVER_SOFTWARE', '').startswith('Google App Engine') or
    os.getenv('SETTINGS_MODE') == 'pushtolive'):
    # Running on production App Engine, so use a Google Cloud SQL database.
    DATABASES = {
        'default': {
            'ENGINE': 'google.appengine.ext.django.backends.rdbms',
            'INSTANCE': 'xyz:xyz',
            'NAME': 'my_database',
        }
    }
else:
    # Running in development, so use a local SQLite database
    DATABASES = {
        'default': {
            'ENGINE': 'django.db.backends.sqlite3',
            'NAME': '/tmp/mysite.db',
        }
    }

当我打开任何 url(例如 127.0.0.1:8080)时,我就会遇到这个可怕的堆栈跟踪。我剥离了堆栈跟踪,使其更具可读性:

ERROR    2012-12-29 09:07:06,223 base.py:215] Internal Server Error: /favicon.ico
Traceback (most recent call last):
  File "/Users/philipp/python/mysite/urls.py", line 4, in <module>
    from django.contrib import admin
  File ".../google_appengine/lib/django_1_4/django/contrib/admin/__init__.py", line 3, in <module>
    from django.contrib.admin.helpers import ACTION_CHECKBOX_NAME
  File ".../google_appengine/lib/django_1_4/django/contrib/admin/helpers.py", line 2, in <module>
    from django.contrib.admin.util import (flatten_fieldsets, lookup_field,
  File ".../google_appengine/lib/django_1_4/django/contrib/admin/util.py", line 1, in <module>
    from django.db import models
  File ".../google_appengine/lib/django_1_4/django/db/__init__.py", line 40, in <module>
    backend = load_backend(connection.settings_dict['ENGINE'])
  File ".../google_appengine/lib/django_1_4/django/db/__init__.py", line 34, in __getattr__
    return getattr(connections[DEFAULT_DB_ALIAS], item)
  File ".../google_appengine/lib/django_1_4/django/db/utils.py", line 92, in __getitem__
    backend = load_backend(db['ENGINE'])
  File ".../google_appengine/lib/django_1_4/django/db/utils.py", line 24, in load_backend
    return import_module('.base', backend_name)
  File ".../google_appengine/lib/django_1_4/django/utils/importlib.py", line 35, in import_module
    __import__(name)
  File ".../google_appengine/lib/django_1_4/django/db/backends/sqlite3/base.py", line 14, in <module>
    from django.db import utils
ImportError: cannot import name utils

从堆栈跟踪中我读到执行运行到django.db.utils模块,然后进入django.db.backends.sqlite3.base,然后它尝试django.db.utils再次跳转,但随后奇怪地失败了。

问题似乎出在 GAE 环境中,因为它有效:

python mysite/manage.py syncdb

这也是:

python mysite/manage.py shell
>>> from django.contrib.auth.models import User
>>> u = User(username="hans")
>>> u.save()
>>> User.objects.all()
[<User: hans>]

到目前为止我尝试了什么:

  • 从/到 Django 1.3/1.4 切换
  • 卸载GAE,重新安装
  • 我尝试了谷歌为“django.db import utils 中的 ImportError”揭示的所有解决方案
  • 这个类似的问题。我尝试执行问题中的语句,但没有遇到问题。

我在 OS X 10.8.2 我的 PYTHONPATH 是:/usr/local/google_appengine:/usr/local/google_appengine/lib/django_1_4

4

3 回答 3

4

由于在 dev 中使用 sqlite 和在生产中使用 mysql(Cloud SQL 使用)不是一个好习惯,我不向任何人推荐这种设置。

然后,有一个选项:这用于在使用 Google 数据存储--use_sqlite时加快开发速度。Cloud SQL 没有类似的选项。

于 2012-12-31T09:56:06.420 回答
4

这可以通过附加_sqlite3_WHITE_LIST_C_MODULESin将 sqlite3 模块列入白名单来解决/usr/local/google_appengine/google/appengine/tools/dev_appserver_import_hook.py

请注意,您需要在应用引擎启动器中选择“制作符号链接...”才能从/usr/local.

于 2013-02-13T13:05:31.467 回答
1

在最新版本的 SDK 中,您可以通过添加在沙箱中启用 sqlite3 模块

'sqlite3' in name.lower()

在 google-app-engine/google/appengine/tools/devappserver2/python/sandbox.py 的 _should_keep_module 函数中(第 195 行左右)

于 2013-04-17T11:30:15.703 回答