Django non può syncdb dopo goccia / creare il database
-
22-09-2019 - |
Domanda
ho voluto ripristinare un database e ha emesso un database goccia seguito da un database di creare su un server PostgreSQL accede tramite psycopg2 da un app Django.
Quando faccio syncdb ./manage.py ottengo il seguente errore:
(prod)root@ns204612:/home/someproject/prod/django-mingus/mingus# ./manage.py syncdb
Traceback (most recent call last):
File "./manage.py", line 16, in <module>
execute_manager(settings)
File "/home/someproject/prod/lib/python2.6/site-packages/django/core/management/__init__.py", line 362, in execute_manager
utility.execute()
File "/home/someproject/prod/lib/python2.6/site-packages/django/core/management/__init__.py", line 303, in execute
self.fetch_command(subcommand).run_from_argv(self.argv)
File "/home/someproject/prod/lib/python2.6/site-packages/django/core/management/base.py", line 195, in run_from_argv
self.execute(*args, **options.__dict__)
File "/home/someproject/prod/lib/python2.6/site-packages/django/core/management/base.py", line 222, in execute
output = self.handle(*args, **options)
File "/home/someproject/prod/lib/python2.6/site-packages/django/core/management/base.py", line 351, in handle
return self.handle_noargs(**options)
File "/home/someproject/prod/lib/python2.6/site-packages/django/core/management/commands/syncdb.py", line 52, in handle_noargs
tables = connection.introspection.table_names()
File "/home/someproject/prod/lib/python2.6/site-packages/django/db/backends/__init__.py", line 491, in table_names
return self.get_table_list(cursor)
File "/home/someproject/prod/lib/python2.6/site-packages/django/db/backends/postgresql/introspection.py", line 30, in get_table_list
AND pg_catalog.pg_table_is_visible(c.oid)""")
File "/home/someproject/prod/lib/python2.6/site-packages/django/db/backends/util.py", line 19, in execute
return self.cursor.execute(sql, params)
psycopg2.InternalError: current transaction is aborted, commands ignored until end of transaction block
e nel registro di PostgreSQL ho ottenuto il seguente errore:
2010-01-24 01:08:02 CET ERROR: relation "django_site" does not exist
2010-01-24 01:08:02 CET STATEMENT: SELECT "django_site"."id", "django_site"."domain", "django_site"."name" FROM "django_site" WHERE "django_site"."id" = 1 ORDER BY "django_site"."domain" ASC
2010-01-24 01:08:02 CET ERROR: current transaction is aborted, commands ignored until end of transaction block
2010-01-24 01:08:02 CET STATEMENT:
SELECT c.relname
FROM pg_catalog.pg_class c
LEFT JOIN pg_catalog.pg_namespace n ON n.oid = c.relnamespace
WHERE c.relkind IN ('r', 'v', '')
AND n.nspname NOT IN ('pg_catalog', 'pg_toast')
AND pg_catalog.pg_table_is_visible(c.oid)
2010-01-24 01:08:02 CET LOG: could not receive data from client: Connection reset by peer
2010-01-24 01:08:02 CET LOG: unexpected EOF on client connection
Come posso risolvere questo favore?
Soluzione
La causa di questo è stato un problema in django-richiesta che viene utilizzato da Django-Mingus. Durante SyncDB Django fa alcune db introspezione e un'importazione relativi sollevato questa eccezione. Se siete a tirare gli ultimi bit sia da Django-request o django-Mingus vi troverete bene.
Altri suggerimenti
Prova a resettare voi banca dati come ./manage.py azzeramento your_app
ho avuto lo stesso problema e rintracciato verso il basso per il commit a 2979ea3d4541f7b3c51c17e160bc95b468ac999b su django-Mingus
Se si ripristinano torna a commettere 2f7eb8de7e2cb1c776e801a40f008048fcbb6d36, la sincronizzazione dovrebbe accadere bene.
mySQL non invalida la transazione corrente quando incontra un errore in cui Postgres genera l'errore e non vengono eseguiti altra query fino a quando la transazione corrente non viene interrotta. In questo caso devi uccidere la transazione o commettere con tale operazione id
Guarda qui http://www.faqs.org/docs/ppbook/ x15040.htm