Backing up Discourse with RDS
We are launching a community site with Discourse at CircleCI and I ran into some issues with performing backups.
Since we want to be #webscale, rather than installing Discourse using the easy Docker method, we opted to split up the services on AWS.
We are using EC2, RDS, ElasticCache, ELB and S3 for backups. When I initially launched PostgreSQL on RDS I just picked the latest version (9.4 at time of writing) and didn’t put much thought into it. The problem is that the version of pg_dump inside the Docker container provided by Discourse is 9.3. Apparently you are not able to do a pg_dump when your client and server are mismatched.
When you try to do this, you get a sad error that states:
aborting because of server version mismatch
In order to fix this, we need to upgrade the client version on the Docker container (or alternatively avoid this all together by using the same version of PostgreSQL on RDS). Since it is easier to update the client than downgrade RDS, I opted to upgrade the client.
To do this:
- Log into the EC2 Instance that is running Discourse
- Go to the Discourse install location (mine is in /var/docker)
- Enter the container with:
sudo ./launcher enter app - Upgrade the version of PostgreSQL client
apt-get install postgresql-9.4 - Swap out the pg_dump symbolic link for the newer version
ln -s /usr/lib/postgresql/9.4/bin/pg_dump /usr/bin/pg_dump - Perform your backup
Thank you for reading! Share your thoughts with me on bluesky, mastodon, or via email.
Check out some more stuff to read down below.
Most popular posts this month
- My Custom Miniflux CSS Theme
- SQLite DB Migrations with PRAGMA user_version
- Making cgit Pretty
- 2024
- Setting up ANTLR4 on Windows
Recent Favorite Blog Posts
This is a collection of the last 8 posts that I bookmarked.
- Pluralistic: AI "journalists" prove that media bosses don't give a shit (11 Mar 2026) from Pluralistic: Daily links from Cory Doctorow
- Avi Alkalay: Uniqlo T-Shirt Bash Script Easter Egg from Fedora People
- Offline 23 hours a day from Derek Sivers blog
- Pluralistic: California can stop Larry Ellison from buying Warners (28 Feb 2026) from Pluralistic: Daily links from Cory Doctorow
- On Alliances from Smashing Frames
- Acting ethically in an imperfect world from Smashing Frames
- Diffusion of Responsibility from Smashing Frames
- My AI Adoption Journey from Mitchell Hashimoto
Articles from blogs I follow around the net
I was inconsiderate but now I’m everywhere
When I was in the music business, there was a record producer who lived in New Jersey, but refused to come into New York City. Anyone that wanted to meet with him had to drive all the way down to his little town. I thought, “What’s his problem? Is he lazy o…
via Derek Sivers blog March 12, 2026Pluralistic: AI "journalists" prove that media bosses don't give a shit (11 Mar 2026)
Today's links AI "journalists" prove that media bosses don't give a shit: In case there was ever any doubt. Hey look at this: Delights to delectate. Object permanence: Eggflation x excuseflation; Haunted Mansion stretch portraits; "Los…
via Pluralistic: Daily links from Cory Doctorow March 11, 2026Generative AI vegetarianism
For some spicier takes! Anthony Moser’s “I Am An AI Hater”, Jenny Zhang’s “choosing friction”, Rusty Foster’s “A.I. Isn’t People”, or Ed Zitron’s “The Case Against Generative AI” if you have most of an afternoon to read it. Emily Bender and Alex Hanna’s p…
via Sean Boots March 11, 2026Generated by openring