如何 运行 针对 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。
目前,我已经在 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。