From IndieWeb
Jump to navigation Jump to search

A backup of an indieweb site should have everything necessary to redeploy it on a new webhost. Typical backups include static files and database exports.


Keeping backups gives you more control over data. When you only keep one copy of your data, you become dependent on a particular service, platform, or technology to work to access your work. With a backup, there is a secondary (or further) copy to which you can refer if the primary copy of your work becomes unavailable.


Backups are commonly stored locally or on a cloud service.

Cloud Service

Cloud services such as Google Drive and Dropbox provide storage solutions to their users. These platforms typically charge their users for usage of their storage facilities. These charges can be explicitly for storage or part of another service, such as in the case of Google Drive and GSuite.

Local Backups

Local backups are stored on USB drives, hard drives, floppy disks, home servers, or other mediums of storage. These backups are physically accessible to their owner. This reduces the common risks associated with using cloud services, such as a service outage impacting access to a service.

Platform Examples

Indie Box

The Indie Box Project has defined a general-purpose backup file format that supports multiple web apps installed at the same hostname (aka site), and multiple sites backed to the same zip file, with full meta-data.


Manage your all the files necessary to build your jekyll site in a git repository (or another distributed SCM system if you prefer). Make clones to all of your devices and create mirrors on free git hosting services like Github or Bitbucket. The key to this strategy is setting up a working environment on a number of different computers. Every time you revisit these different environments to make a post to the site, you are making a distributed backup of your website (through the pull, add, commit, push workflow). You must also back up any configuration or automation files of your web server (in the same or separate repo), unless you use a jekyll specific web server that mimics github-pages and does not require additional configuration. You can also look into setting up special git mirror remotes so that pushing changes to your build/web server pushes out multiple copies to multiple locations.

Jekyll stores files in plain-text using markdown and HTML. This means that Jekyll backups are not susceptible to the drawbacks associated with the database antipattern.

IndieWeb Examples


capjamesg used to mirror his code from GitHub to sourcehut. When he updates a Git repository that is connected to his web API, a webhook request is sent to his API which mirrors his code to sourcehut.

This approach was chosen to create a third location where James stores his website. This setup means that if his local machine and GitHub account are inaccessible, he can go to sourcehut.

kbs notes backup

Just a quick pointer to a couple of things on managing backups in general (not specific to indieweb.) This polemic by jwz is a useful read -

My personal preference is to have a local copy of anything before publishing it (and I don't publish much either.) I also like to have a local backup of my gmail, photos from my phone, shared facebook photos from select people and content from a few other silos. for some thoughts on why and what I try to preserve.

My solution is rather crude - I try to keep two hard-drives with monthly snapshots (rather than a "latest" backup) with something like

nohup rsync -aP --link-dest=/Volumes/Backup/macbook-home-2014-01-01 /Users/kbs /Volumes/Backup/macbook-home-2014-02-01

It also creates an encrypted tarball of critical folders to dropbox and gdrive at this time. A little app on my phone also uploads photos to dropbox, and my laptop periodically moves them into my personal photo folders so these are also backed up eventually.

Every two-three years (I've managed to do this for about 10 years now) I re-copy these two hard drives to new media, and leave the old media in one or other of my friends place.

See Also