Manually update Discourse and Docker image to latest

If you self-host Discourse, you occasionally need to run a manual update via the command line to get the latest security releases newest libraries. These updates are not picked up in admin/update, which is why you’ll occasionally need to do this additional step.

  1. Discourse itself should be updated about twice a month, by clicking the “Update to Latest Version” button in your admin dashboard (admin/update).

  2. Every two months we recommend SSH’ing into your web server (using putty or your favorite SSH client) and doing

    cd /var/discourse
    ./launcher rebuild app
    

    Especially if the upgrade page doesn’t show up or you have any issues when trying to upgrade.

  3. As for Ubuntu updates, make sure you have automatic security updates enabled for your Ubuntu! The command is:

    dpkg-reconfigure -plow unattended-upgrades
    

    However, that just covers critical security updates. Every so often you should get all the OS updates like so:

    apt-get update
    apt-get dist-upgrade
    

Due to the way docker packaging has changed you may also have to update your docker from lxc-docker or docker-engine packages. One way to do that is via the Docker script here (it will warn about an existing install but should upgrade ok):

wget -qO- https://get.docker.com/ | sh

This will now use the docker-ce main versions.

This is completely safe, we have never seen anything get broken by base Ubuntu updates.

To summarize:

  • update Discourse twice a month via web updater
  • update the container every two months
  • update the OS every six months

You could double these numbers and still be fairly safe, e.g. update Discourse once a month, container every 4 months, OS once every 12 months, and so on.

But you really, really want automatic security updates enabled in Ubuntu, as listed above.

FAQ

What is the right time to update?

It just depends on the time you have available and how close to bleeding edge you want to be. If you have non-official plugins, it is highly advisable to utilize a test/staging site. If you do not have any non-official plugins, you can likely upgrade immediately, but even then, some plugins may break for a couple of days as the team fixes them (there are a lot of them).

What is common practice when updating with many plugins installed?

If you have a lot of plugins, testing locally or on a test server is highly advised. Especially if you have non-official plugins, as something could have broken. If you find something does break, then it is a matter of, do you have time to fix it? Does the original plugin author have time to fix it? Either of those could take weeks. So at least this way, you simply have a broken test site and not a broken production site.

I’m running low on disk space

If you are running low on disk space (check with df) try clearing up old images using:

./launcher cleanup
apt-get autoclean
apt-get autoremove

Does updating the actual server version of Ubuntu matter since Discourse always operates in Docker?

It matters a lot less. But you should be on at least a currently supported LTS release of Ubuntu server. A 64-bit Linux OS with a modern kernel version is required.

174 Likes

The guides are reviewed and updated fairly frequently (this one looks like it had a little tweak in February). :+1:

The only one in there that I’m not personally familiar with is the docker one:

But I can vouch for the accuracy of the rest. :slight_smile:

2 Likes

I just ran through the entirety of these commands on my test site, including the docker update, and they worked without any problems.

4 Likes

I’ve had a report of this causing an issue when run. I don’t think I’ve ever used it myself in the couple of years of having a DO test site.

Does anyone have any recent experience of it to say whether it’s still relevant advice or not?


I’ve just had a browse of the deleted posts and I found a couple where that part of the guide was raised before [1] and it seems @MarkDoerr ran it with no issues.

Though I’m still unsure if when/under what circumstances you’d be required to run it? Do I have too much faith in Docker Manager?


  1. I’ve undeleted them ↩︎

2 Likes

2 posts were split to a new topic: When to update the data container of a two container setup?

A post was split to a new topic: Upgrading v2.2.0.beta4 forum with unknown local changes

Have tried running that command (wget -qO- https://get.docker.com/ | sh) now and reports:

Cannot connect to the Docker daemon at unix:///var/run/docker.sock. Is the docker daemon running?

Seems like this has not worked to update docker.

Also seems to have caused entire site to crash, and cannot rebuild app reports:

Cannot connect to the docker daemon - verify it is running and you have access

After rebooting server site is back online.

So maybe it did do the upgrade but failed to restart docker. You can check with

docker --version

It turns out my laptop had an old docker and I ran the recommended commmand and did not have to reboot for it to work. Here’s what I get for the version:

$ docker --version
Docker version 26.1.4, build 5650f9b
1 Like

Have same docker version:

Docker version 26.1.4, build 5650f9b
1 Like

Then you’re up to date and all is well!

3 Likes

I knew I’d seen this doc covering the Discourse update cadence, but had trouble finding it again because it’s in Documentation under “Using Docker” and titled “Manually update Docker.”

Since it covers Discourse and Ubuntu updates, could it also have another place or two on the menu?

1 Like