无法在本地连接到Heroku postgre SQL数据库

时间:2016-09-06 09:23:21

标签: python postgresql heroku

我正试图像这样在本地连接到Heroku postgre SQL数据库,

from flask import Flask
import sys
import psycopg2
import urlparse

urlparse.uses_netloc.append("postgres")
url = urlparse.urlparse("postgres://url")

conn = psycopg2.connect(
    database=url.path[1:],
    user=url.username,
    password=url.password,
    host=url.hostname,
    port=url.port
)

但经过漫长的停顿后,我收到以下错误,

psycopg2.OperationalError: could not connect to server: Connection timed out
    Is the server running on host "URL" (IP) and accepting
    TCP/IP connections on port 5432?

如何修复此错误并在本地连接到数据库?

1 个答案:

答案 0 :(得分:0)

我有点难以缩小范围,但我能够通过这些步骤设置类似的东西:

如果你有一个' server.py'确保将此文件放在文件的顶部:

from dotenv import load_dotenv, find_dotenv
import os

load_dotenv(find_dotenv())
db = pg.DB(
  dbname=os.environ.get('DBNAME'),
  host=os.environ.get('DBHOST'),
  port=int(os.environ.get('DBPORT')),
  user=os.environ.get('DBUSER'),
  passwd=os.environ.get('DBPASSWORD')
)

将以下内容转储到Procfile中(拼写Procfile完全相同)

web: gunicorn -b 0.0.0.0:$PORT -w 4 server:app

最后,您需要一个requirements.txt,其中列出了您已安装的所有Python模块。您可以使用以下命令执行此操作:pip freeze> requirements.txt

希望有所帮助。