Move topics from one Discourse instance to another

Need to move some stuff from one instance of Discourse to another?

There is a command line tool to export a topic, a set of topics, or an entire category, and another to import them in at the other end.

Topic Export/Import

  • one or more topics and their replies
  • the users who posted in the topic

Category Export/Import

  • the category and all its subcategories
  • its security settings
  • custom groups mentioned in the security settings
    • :warning: if any of the groups have ‘membership requests’ enabled, it will crash. Turn this off before the export
  • all topics and posts in the category and subcategories
  • all users who posted, and assigns them to the groups

Begin: Identify the IDs

First, identify the ID(s) of the =Export= that you wish to export. You’ll find this at the end of the URL used to access it.

  • https://meta.discourse.org/t/how-to-contribute-to-discourse/53797

  • https://meta.discourse.org/t/how-to-contribute-to-discourse/53797/12
    (in this case you are in the middle of a topic - grab the first number)

  • https://meta.discourse.org/c/howto/faq/4

Category or Topic ID(s)

Multiple topics

You can select more than one topic by adding IDs separated by a space; this works in the field above (I don’t think that this works for categories though):

  • 53797 200943 124096

Run the Export Script

The tool can be run as a root user inside the container:

cd /var/discourse
./launcher enter app

Run this command:

discourse export_=Export= =ID=

The output should look something like this:

Starting export of =Export=…

Where are the new users all coming from?
Export saved to =Export=-export-2021-08-27-015437.json

Done

Move the Exported File

The exported .json file needs to be moved from the inside of the application container where you did the export to the inside of the container of the receiving instance. This takes a few steps.

Copy it to the ‘outside’

Exit the container if you haven’t already

exit

You should now have a prompt like this:

root@yourserver:/var/discourse

Use docker to copy the file out of the container (you can’t move it I don’t think)

docker cp app:/var/www/discourse/=FileName= .

Move it to the other instance

This is beyond the scope of this guide, but this might help you get there:

Copy it into the container in the receiving instance

SSH into your receiving instance as root and get to the Discourse directory:

cd /var/discourse

Use docker once again to copy the file into the other container

docker cp =FileName= app:/var/www/discourse

Import the Content

Enter the container in the receiving instance:

./launcher enter app

Run the import script

discourse import_=Export= =FileName=

:cake: Done!

You might need to tidy up some loose ends, but hopefully, it should all be done.

Advanced Tips

Missing Ruby Gem

When doing a complex category import, my instance was missing the ‘Listen’ Ruby.
This was solved by doing this: (using the Discourse user inside the container)

./launcher enter app
su discourse
bundle config --delete without
bundle config --delete with
bundle install
exit
exit

This broke the rails console, necessitating a rebuild afterwards

./launcher rebuild app

Multisite

In a multisite environment, use the RAILS_DB env variable.

RAILS_DB=xxxmoves discourse export_=Export= =ID=
RAILS_DB=dancerehab discourse discourse import_=Export= =FileName=

Please report bugs in the bug category, and request enhancements in the feature category.


Related Topics


Last Reviewed by @SaraDev on 2022-07-13T00:00:00Z

Last edited by @hugh 2024-05-29T06:25:11Z

Check documentPerform check on document:
43 Mi Piace

Ci riprovo.

C’è un modo semplice per migrare i caricamenti pertinenti insieme agli argomenti?

Non proprio. Una cosa che funziona per lo più è se prendi tutti quei caricamenti e incolli l’URL dell’originale in qualsiasi post sul sito a cui ti stai spostando, quindi quello che dovrebbe succedere è che quei caricamenti verranno creati con lo stesso SHA e Funziona e basta.

Quindi faresti la cosa che converte le cose nel post nell’URL per ottenere quegli URL. (Non riesco mai a ricordare come si fa, quindi devo scoprirlo ogni volta).

Hmmm - rimango un po’ confuso da questo. Stai dicendo che questo funzionerà?

  1. Prendi tutti i file di caricamento dal primo sito
    • come?
  2. Inseriscili in un singolo argomento
  3. Genereranno lo stesso link relativo che avevano nel vecchio sito e magia!

Oppure intendevi questo?

  1. Prendi tutti gli URL assoluti nelle tue categorie di interesse dal vecchio sito
  2. Incollali in un argomento
  3. Verranno tutti scaricati nel nuovo sito con lo stesso SHA e i link esistenti funzioneranno magicamente

O qualcos’altro interamente?

Penso che uno dei due dovrebbe funzionare. Tuttavia, puoi caricare quelle immagini sul nuovo sito, dovrebbero generare lo stesso sha, così i link esistenti negli argomenti funzioneranno magicamente.

Forse potresti fare qualcosa del genere

cat_id=123
Topic.where(category_id: cat_id).each do| t|
  Post.where(topic_id: t.id) do |p|
      p.cooked.match(image url)....
         puts(the match) 

E penso che se fai questo e incolli quei link in un post ovunque sul tuo sito, scaricherà tutte quelle immagini localmente e creerà lo stesso sha, quindi quegli stessi link. Puoi provarne un paio manualmente per vedere.

È nel cuore della notte. La tua esperienza potrebbe variare.

1 Mi Piace

Ciao, non sono sicuro che questo tutorial sia quello che voglio fare, ma sollevo la domanda qui.

Se installo Discourse su un server, ma a causa della crescita ho bisogno di migrare su uno più potente, questi sono i passaggi?

Cosa succede, ad esempio, con l’opzione di backup? Non posso farlo, installare Discourse su un altro server e poi ripristinare la copia di backup dell’altra istanza da quell’opzione?

Attendo un tuo chiarimento, poiché voglio sapere come migrare quando ne avrò bisogno e non perdere il lavoro che ho svolto di recente.

No. Per spostare un sito su un server più grande è sufficiente un semplice backup e ripristino. Puoi anche Spostare un sito Discourse su un altro VPS con rsync