Hello Self-Hosters,
What is the best practice for backing up data from docker as a self-hoster looking for ease of maintenance and foolproof backups? (pick only one :D )
Assume directories with user data are mapped to a NAS share via NFS and backups are handled separately.
My bigger concern here is how do you handle all the other stuff that is stored locally on the server, like caches, databases, etc. The backup target will eventually be the NAS and then from there it’ll be double-backed up to externals.
- 
Is it better to run cp /var/lib/docker/volumes/* /backupLocationevery once in a while, or is it preferable to define mountpoints for everything inside of/home/user/Containersand then use a script to sync it to wherever you keep backups? What pros and cons have you seen or experienced with these approaches?
- 
How do you test your backups? I’m thinking about digging up an old PC to use to test backups. I assume I can just edit the ip addresses in the docker compose, mount my NFS dirs, and failover to see if it runs. 
- 
I started documenting my system in my notes and making a checklist for what I need to backup and where it’s stored. Currently trying to figure out if I want to move some directories for consistency. Can I just do docker-compose downedit the mountpoints indocker-compose.ymland rundocker-compose upto get a working system?


While that’s an easy solution it makes it impossible or rather difficult to restore single containers and/or files.
It’s not that difficult. You can create a second VM from the backup with a few clicks and move the necessary data with scp.
It’s pretty easy, you can browse files in an LXC backup and restore specific parts. For VMs you can just restore the whole VM and copy out what you need.
bs