mirror of
https://github.com/discourse/discourse.git
synced 2025-02-23 08:41:54 +08:00
60 lines
2.4 KiB
Markdown
60 lines
2.4 KiB
Markdown
Deploying [Discourse on Docker][1] is currently our recommended setup. It avoids many pitfalls installations have, such as misconfigured nginx, sub-optimal Ruby defaults and so on.
|
|
|
|
The Docker based setup ensures we are all on the same page when diagnosing installation issues and completely eradicates a class of support calls.
|
|
|
|
Today, all sites hosted by Discourse are on Docker.
|
|
|
|
This is a basic guide on how to move your current Discourse setup to a Docker based setup.
|
|
|
|
## Getting started
|
|
|
|
First, get a blank site with working email installed. Follow the guide at https://github.com/discourse/discourse_docker and install a new, empty Discourse instance.
|
|
|
|
**Tips:**
|
|
|
|
- Bind the web to a different port than port 80, if you are on the same box. Eg:
|
|
|
|
expose:
|
|
- "81:80"
|
|
|
|
- Be sure to enter your email in the developer email section, so you get admin:
|
|
|
|
env:
|
|
# your email here
|
|
DISCOURSE_DEVELOPER_EMAILS: 'my_email@email.com'
|
|
|
|
|
|
- Make sure email is setup and working by visiting `/admin/email` and sending a test email.
|
|
|
|
- Make sure you have ssh access to your container `./launcher ssh my_container` must work.
|
|
|
|
**If any of the above is skipped your migration will fail.**
|
|
|
|
At the end of this process you will have a working website. Carry on.
|
|
|
|
|
|
## Exporting and importing the old site
|
|
|
|
- Ensure you are running the absolute latest version of Discourse. We had bugs in the export code in the past, make sure you are on latest before attempting an export.
|
|
|
|
- On your current instance
|
|
- go to `/admin/backups` and click on the data:image/s3,"s3://crabby-images/0a365/0a365796235dc8d73ebfce0d68008baced092828" alt="Backup" button.
|
|
- once the backup is done, you will be able to data:image/s3,"s3://crabby-images/95cf3/95cf3c0e01d549be4fefcd084cc92bdc1653068d" alt="Download" it.
|
|
|
|
- On your newly installed docker instance
|
|
- enable the `allow_restore` site setting
|
|
- refresh your browser for the change to be taken into account
|
|
- go to `/admin/backups` and data:image/s3,"s3://crabby-images/37560/3756025fe36af253d95ec6c74e7843429c9b2342" alt="Upload" your backup.
|
|
- once your upload is done, click on the data:image/s3,"s3://crabby-images/03ade/03ade2749e76542cffe6c5bf18dfe9cd11f84ae8" alt="Restore" button
|
|
|
|
|
|
- Destroy old container `./launcher destroy web`
|
|
|
|
- Change port binding so its on 80
|
|
|
|
- Start a new container
|
|
|
|
Yay. You are done.
|
|
|
|
[1]: INSTALL-digital-ocean.md
|