我有一个django应用程序在本地运行良好,但当我将其部署到谷歌云时,会引发服务器错误500。它是在一个灵活引擎上,我跟着these very good instructions设置一切。
它告诉我数据库不存在。 (确实如此。)
已解决:我没有意识到实例和数据库之间存在差异。实例存在,但数据库没有。我在实例中创建了数据库,现在一切正常。
{
insertId: "s=81237568d9204e6081d81087faf41900;i=162cc;b=0ca68bbe363d49a581ec4e2fc6c45487;m=799aa9bfc;t=57529446a6708;x=4f176b686e1cb7ce-0@a1"
logName: "projects/rcg-live/logs/cloudsql.googleapis.com%2Fpostgres.log"
receiveTimestamp: "2018-09-06T00:49:51.309738251Z"
resource: {…}
severity: "ALERT"
textPayload: "FATAL: database "rcg-live-db" does not exist"
timestamp: "2018-09-06T00:49:45.486088Z"
}
当我尝试使用云sql代理工具连接本地应用程序时,我得到相同的错误:
Traceback (most recent call last):
File "/anaconda3/lib/python3.6/site-packages/django/db/backends/base/base.py", line 216, in ensure_connection
self.connect()
File "/anaconda3/lib/python3.6/site-packages/django/db/backends/base/base.py", line 194, in connect
self.connection = self.get_new_connection(conn_params)
File "/anaconda3/lib/python3.6/site-packages/django/db/backends/postgresql/base.py", line 174, in get_new_connection
connection = Database.connect(**conn_params)
File "/anaconda3/lib/python3.6/site-packages/psycopg2/__init__.py", line 130, in connect
conn = _connect(dsn, connection_factory=connection_factory, **kwasync)
psycopg2.OperationalError: FATAL: database "rcg-live-db" does not exist
settings.py看起来像这样:
DATABASES = {
'default': {
'ENGINE': 'django.db.backends.postgresql',
'HOST': os.environ['DB_HOST'],
'PORT': os.environ['DB_PORT'],
'NAME': os.environ['DB_NAME'],
'USER': os.environ['DB_USER'],
'PASSWORD': os.environ['DB_PASSWORD']
}
}
我确定app.yaml文件配置正确...它找到了密钥,首次亮相设置在我更改时响应,两者都由app.yaml控制
我不太确定我能在这里说明我的云上存在一个名为'rcg-live-db'的postgres数据库,所以我想我的话就是这样。
再一次,一切都在本地工作,包括管理页面。当我尝试使用远程数据库时,所有500个错误。
已解决:我没有意识到实例和数据库之间存在差异。
实例存在,但数据库没有。
我在实例中创建了数据库,现在一切正常。