Errore di importazione backup: "could not create unique index"

Ciao,

Sto tentando di migrare un forum su un nuovo server. Entrambi i server eseguono l’ultima versione di discourse docker. Quando importo il backup tramite riga di comando, ricevo il seguente errore:

ERRORE:  impossibile creare indice univoco "index_incoming_referers_on_path_and_incoming_domain_id"
DETTAGLIO:  La chiave (path, incoming_domain_id)=(/search/, 418) è duplicata.
ECCEZIONE: psql fallito: DETTAGLIO:  La chiave (path, incoming_domain_id)=(/search/, 418) è duplicata.

Questo sembra lo stesso errore o simile a:

Tuttavia, nel mio caso i record duplicati si trovano nel percorso /search/ anziché /m/search come nel thread collegato sopra.

Mi sono connesso al container sul vecchio server (./launcher enter app) e nella console Rails (rails c) ho provato a cercare i record duplicati usando:

IncomingReferer.where(path: "/search")
e
IncomingReferer.where("path LIKE '%/search%'")

Tuttavia, questo risulta in centinaia di record visualizzati. Come posso capire quali record sono duplicati e come posso eliminarli in modo sicuro e ricostruire? Il forum funziona correttamente sul vecchio server, dobbiamo solo spostarci su nuovo hardware.

1 Mi Piace

Have you tried using the Admin GUI ?

1 Mi Piace

No, I assumed importing via the GUI would be invoking the same import process? I’ll try that now.

1 Mi Piace

I suspect this means that you have a corrupt index. What version of Postgres are you running?

something like:

cd /var/discourse
cat shared/standalone/postgres_data/PG*

(I can’t quite remember the postgres filename).

You can search here for “postgres corrupt index” and find a topic that I once wrote about how to track down those bad records and delete them.

You basically try to rebuild that index and delete the records that it complains about then try to rebuild the index again until it rebuilds.

Just tried importing via the GUI, with exactly the same result:

The old server doesn’t have a file called PG_VERSION, how can I tell what version its running? I’ve updated the docket install to the latest version today.

The new server (newly bootstrapped) is running postgres V13

cat shared/standalone/postgres_data/PG_VERSION
13

Is there a recommended procedure on how to do this?

I had a topic that had some hints, but I don’t see it anymore. It’s been close to a year since the postgres 12 upgrade.

  reindex index index_incoming_referers_on_path_and_incoming_domain_id;

And

 ActiveRecord::Base.connection.execute('reindex index index_incoming_referers_on_path_and_incoming_domain_id;')

Are ways to try to rebuild the index. It’ll give you an error and you can then go and delete the errant records. You’ll need to include both the path and the ID.

Ok, I’ve fixed it. I did the following

Enter container

./launcher enter app

Connect to database

su postgres -c 'psql discourse'

Try to find duplicates

discourse=# select * from incoming_referers where path LIKE '%/search/' ORDER BY incoming_domain_id;`

  id  |    path    | incoming_domain_id
------+------------+--------------------
 3339 | /search/   |                 33
 6257 | /search/   |                 91
 1567 | /search/   |                298
 1777 | /search/   |                341
 3010 | /search/   |                418
 6247 | /search/   |                418
 4293 | /search/   |                644
 2899 | /search/   |                653
 3447 | /search/   |                793
 3696 | /search/   |                852
 4395 | /a/search/ |               1050
 6968 | /search/   |               1305
 5634 | /search/   |               1387
 5834 | /search/   |               1437
 6519 | /search/   |               1637
 7127 | /search/   |               1787
 7280 | /search/   |               1827
(17 rows)

Delete duplicate

DELETE FROM incoming_referers WHERE path LIKE '%/search/' AND id IN (6247);

Then rebuild

discourse=# REINDEX SCHEMA CONCURRENTLY public;
WARNING:  cannot reindex invalid index "public.incoming_referers_pkey_ccnew" concurrently, skipping
WARNING:  cannot reindex invalid index "public.index_incoming_referers_on_path_and_incoming_domain_id_ccnew" concurrently, skipping
WARNING:  cannot reindex invalid index "pg_toast.pg_toast_20732_index_ccnew" concurrently, skipping
REINDEX

Then I took another backup, copied it to the new server, and it imported successfully :smiley:

It would be nice if the backup process could spot duplicates to avoid any issues, I was luckily that I had access to the original server which was still running. If I was restoring a cold backup, this would probably have been more of an issue>

Thanks a lot for your help.

3 Mi Piace

This topic was automatically closed 30 days after the last reply. New replies are no longer allowed.