Django / Google Cloud:致命:数据库 不存在/服务器错误500

问题描述 投票:0回答:1

我有一个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个错误。

python django postgresql google-cloud-platform
1个回答
1
投票

已解决:我没有意识到实例和数据库之间存在差异。

实例存在,但数据库没有。

我在实例中创建了数据库,现在一切正常。

© www.soinside.com 2019 - 2024. All rights reserved.