How to: Compose your Backups (Manually)


One of the great features of Compose databases is that backups are taken automatically. Backups are made on regularly and retained on a daily, weekly and monthly basis. If your processes and procedures demand that you make another backup to be stored elsewhere, we also have you covered with an On Demand backup option. In this article, we'll look at how you can get at those backups and how you can manually make and save those backups. Then, in the next installment, we'll show how you can use the API to automate that process.

Please note these article only apply to Compose Elastic Deployments - Sandboxes accounts have no automated backup. Database accounts provided by third party services such as Heroku have a different backup system with ten days of disk snapshots - for on-demand backups, they are able to use the mongodump utility.

We start with the manual process for backups. To do this you need to be logged in to your database's dashboard on Compose. Sign in and select the database you want to work with. This will take you to the collections view by default. Look to the sidebar on the left and select the Admin option. This will take you to the Admin dashboard.

Admin Overview

At this point, you'll see the overview of your database including salient statistics and other useful information. Other administration views are available by selecting from the tabs at the top of the view. Select the Backups view from those tabs.

Backups View

And what's displayed in this view are all the backups available for this database. You may not have realised it, but there'll already be the 7 daily, 4 weekly and 3 monthly backups that the Compose system retains, assuming of course you've had the database instance for three months.

The square-with-arrow icon on the right next to each backup allows you to download that backup. The circle-and-arrow icon allows you to restore that backup. Note that this doesn't restore it to your current database. Instead, it restores it to a freshly created elastic deployment – this ensures that databases aren't accidentally erased and that the restoration takes place to a database with a known good state.


Anyway, at the top of this list if you have already run one, is the entry for the On-Demand backup. If you haven't created one yet, the Backup Now button in the top right will start the process. If you have already created one, then, when you do press Backup Now you will be prompted to confirm you wish to replace your current On Demand backup. That's because only one On Demand backup is retained at any time. Once you've confirmed, the backup will begin and will be indicated in the backup list like so:

Backing Up Now

When it's done, the table will return to displaying the download and restore icons. Click the download to get your copy of the freshly made On Demand backup. What can you do with this file? Apart from the obvious "store it safely" with a MongoDB backup, you can use the files contained to seed a local MongoDB instance.

Those download and restore icons work for the daily, weekly and monthly backups too, so if you don't want to wait for a fresh backup, you can always get a relatively up-to-date version from the most recent daily backup. On-demand backups are more useful when moving your data between deployments or seeding test systems but you do have to wait for them to be created. If only there was a way to automate that entire process... there is and we'll look at it in the next installment.

Dj Walker-Morgan
Dj Walker-Morgan was Compose's resident Content Curator, and has been both a developer and writer since Apples came in II flavors and Commodores had Pets. Love this article? Head over to Dj Walker-Morgan’s author page to keep reading.

Conquer the Data Layer

Spend your time developing apps, not managing databases.