我正试图像这样在本地连接到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?
如何修复此错误并在本地连接到数据库?
答案 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
希望有所帮助。