如何 运行 针对 Google Cloud SQL 的 Django 管理命令

How to run Django management commands against Google Cloud SQL

目前,我已经在 google 应用引擎上部署了我的 django 项目。我需要 运行 python manage.py migrate 命令以便在我的 google 云实例上创建 auth_user table。但是不知道运行这个命令从哪里来。

如果我没看错,您的应用程序将在 App Engine(沙盒环境)上运行并使用 Cloud SQL。

1) 在 settings.py 中配置您的数据库,如下所示。

if os.getenv('SERVER_SOFTWARE', '').startswith('Google App Engine'):
    # Running on production App Engine, so use a Google Cloud SQL database.
    DATABASES = {
        'default': {
            'ENGINE': 'django.db.backends.mysql',
            'HOST': '/cloudsql/project-id:instance-name',
            'NAME': 'database-name',
            'USER': 'root',
        }
    }
elif os.getenv('SETTINGS_MODE') == 'prod':
    # Running in development, but want to access the Google Cloud SQL instance in production.
    DATABASES = {
        'default': {
            'ENGINE': 'django.db.backends.mysql',
            'INSTANCE': 'cloud-sql-instance-ip-address',
            'NAME': 'database-name',
            'USER': 'root',
            'PASSWORD': 'password',
        }
    }
else:
    # Running in development, so use a local MySQL database.
    DATABASES = {
        'default': {
            'ENGINE': 'django.db.backends.mysql',
            'NAME': 'database-name',
            'USER': 'username',
            'PASSWORD': 'password',
        }
    }

2) 将环境变量 SETTINGS_MODE 设置为 prod(如果要访问本地 MySQL 服务器,则不要设置)。

3) 运行 来自您机器的以下命令。

$ SETTINGS_MODE=prod python manage.py migrate

您可以在 App Engine 文档中找到更多详细信息 - Management commands and Alternate development database and settings