ข้อผิดพลาดการตั้งค่าฐานข้อมูล Django 1.8 postgresql ขณะปรับใช้บน heroku

ดูเหมือนว่าขั้นตอนทั้งหมดทำงานได้ดี แต่เมื่อฉันพยายามเรียกใช้ heroku run python manage.py migrate มันทำให้ฉันมีข้อผิดพลาดแจ้งว่า Is the server running on host "127.0.0.1" and accepting TCP/IP connections on port 5432? ฉันไม่สามารถเข้าใจส่วนนี้ออกได้ ฉันจำเป็นต้องเปลี่ยนการตั้งค่าฐานข้อมูล postgresql ของฉันหรือไม่ แต่ฉันมีข้อมูลอยู่แล้วในฐานข้อมูล postgresql ของฉัน พวกเขาจะถูกย้ายไปยัง heroku ได้อย่างไรหากฉันเปลี่ยนการตั้งค่าฐานข้อมูล

settings.py

 DATABASES = {
    'default': {
      'ENGINE': 'django.db.backends.postgresql_psycopg2',
      'NAME': 'music',                      
      'USER': '**',
      'PASSWORD': '**',
      'HOST': '127.0.0.1',
      'PORT': '5432',
      }
   }

full error traceback

  File "manage.py", line 10, in <module>
  execute_from_command_line(sys.argv)
  File "/app/.heroku/python/lib/python3.4/site- packages/django/core/management/__init__.py", line 338, in execute_from_command_line
  utility.execute()
  File "/app/.heroku/python/lib/python3.4/sitepackages/django/core/management/_
  _init__.py", line 330, in execute
   self.fetch_command(subcommand).run_from_argv(self.argv)
   File "/app/.heroku/python/lib/python3.4/site-     packages/django/core/management/base.py", line 390, in run_from_argv
   self.execute(*args, **cmd_options)
   File "/app/.heroku/python/lib/python3.4/site-   packages/django/core/management/base.py", line 441, in execute
   output = self.handle(*args, **options)
   File "/app/.heroku/python/lib/python3.4/sitepackages/django/core/management/commands/migrate.py", line 93, in handle
   executor = MigrationExecutor(connection,self.migration_progress_callback)
   File "/app/.heroku/python/lib/python3.4/site- packages/django/db/migrations/exe
   cutor.py", line 19, in __init__
   self.loader = MigrationLoader(self.connection)
   File "/app/.heroku/python/lib/python3.4/site-  packages/django/db/migrations/loader.py", line 47, in __init__
   self.build_graph()
   File "/app/.heroku/python/lib/python3.4/site-  packages/django/db/migrations/loader.py", line 180, in build_graph
   self.applied_migrations = recorder.applied_migrations()
   File "/app/.heroku/python/lib/python3.4/site-packages/django/db/migrations/recorder.py", line 59, in applied_migrations
   self.ensure_schema()
   File "/app/.heroku/python/lib/python3.4/site-packages/django/db/migrations/recorder.py", line 49, in ensure_schema
   if self.Migration._meta.db_table in self.connection.introspection.table_names(self.connection.cursor()):
   File "/app/.heroku/python/lib/python3.4/site-packages/django/db/backends/base/base.py", line 164, in cursor
   cursor = self.make_cursor(self._cursor())
   File "/app/.heroku/python/lib/python3.4/site-packages/django/db/backends/base/base.py", line 135, in _cursor
   self.ensure_connection()
   File "/app/.heroku/python/lib/python3.4/site-packages/django/db/backends/base/base.py", line 130, in ensure_connection
   self.connect()
   File "/app/.heroku/python/lib/python3.4/site- packages/django/db/utils.py", line 97, in __exit__six.reraise(dj_exc_type,  dj_exc_value, traceback)
   File "/app/.heroku/python/lib/python3.4/sitepackages/django/utils/six.py", line 658, in reraise
   raise value.with_traceback(tb)
   File "/app/.heroku/python/lib/python3.4/site- packages/django/db/backends/base/base.py", line 130, in ensure_connection
   self.connect()
   File "/app/.heroku/python/lib/python3.4/site- packages/django/db/backends/base/base.py", line 119, in connect
   self.connection = self.get_new_connection(conn_params)
   File "/app/.heroku/python/lib/python3.4/site-packages/django/db/backends/postgresql_psycopg2/base.py", line 176, in  get_new_connection
   connection = Database.connect(**conn_params)
   File "/app/.heroku/python/lib/python3.4/site-packages/psycopg2/__init__.py", line 164, in connect
   conn = _connect(dsn, connection_factory=connection_factory, async=async)
  django.db.utils.OperationalError: could not connect to server: Connection refused
    Is the server running on host "127.0.0.1" and accepting
    TCP/IP connections on port 5432?

person WutWut    schedule 23.06.2015    source แหล่งที่มา
comment
บางทีการกำหนดค่านี้บน postgresql.conf ของคุณอาจช่วยได้: stackoverflow.com/a/17648799/939803   -  person Filipe Manuel    schedule 24.06.2015


คำตอบ (1)


แน่นอนว่าเซิร์ฟเวอร์ db ไม่ทำงานบนเครื่องโลคัลบน Heroku คุณควรปฏิบัติตามเอกสารประกอบ และใช้ฐานข้อมูล dj -url ไลบรารีเพื่อตั้งค่าตำแหน่ง db โดยอัตโนมัติจากสภาพแวดล้อม

person Daniel Roseman    schedule 24.06.2015
comment
แต่คำถามของฉันคือ ฉันจะย้ายข้อมูลฐานข้อมูล postgresql ในเครื่องของฉันไปยังฐานข้อมูลที่ heroku จัดเตรียมไว้ได้อย่างไร - person WutWut; 24.06.2015