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

标签 python django google-app-engine google-cloud-sql

目前,我已经在 google app engine 上部署了我的 django 项目。我需要运行 python manage.py migrate 命令,以便在我的谷歌云实例上创建 auth_user 表。但是不知道在哪里运行这个命令。

最佳答案

如果我做对了,您的应用程序将在 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 commandsAlternate development database and settings .

关于python - 如何针对 Google Cloud SQL 运行 Django 管理命令,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35153942/

相关文章:

python - 省略号对象有什么作用?

Django 2.0 自定义 url 正则表达式

java - App Engine 拉取队列仅加载任务的子集

python - 进行重定向时如何传递模板值?

java - 在 Google 应用引擎上部署失败

python - 属于某个类的函数对象在属性查找时是否会受到特殊处理?

python - 变量和函数帮助//Python

python - Bottle 网络应用程序不提供静态 css 文件

django - 如何调试 Django PayPal IPN?

python - Django 1.4 SimpleListFilter 'selected' 选项问题