mirror of
				https://github.com/immich-app/immich.git
				synced 2025-10-25 07:52:29 -04:00 
			
		
		
		
	feat(docs): Template script for 3-2-1 backup of the assets and database (#6026)
* Added borg template cron job * moved script to guides section * Mentioned db backup location in docs * Added directions for restoring backups
This commit is contained in:
		
							parent
							
								
									d3af2b1f69
								
							
						
					
					
						commit
						ad09896f58
					
				| @ -1,5 +1,7 @@ | |||||||
| # Backup and Restore | # Backup and Restore | ||||||
| 
 | 
 | ||||||
|  | A [3-2-1 backup strategy](https://www.backblaze.com/blog/the-3-2-1-backup-strategy/) is recommended to protect your data. You should keep copies of your uploaded photos/videos as well as the Immich database for a comprehensive backup solution. This page provides an overview on how to backup the database and the location of user-uploaded pictures and videos. A template bash script that can be run as a cron job is provided [here](../guides/template-backup-script) | ||||||
|  | 
 | ||||||
| ## Database | ## Database | ||||||
| 
 | 
 | ||||||
| :::caution | :::caution | ||||||
|  | |||||||
							
								
								
									
										82
									
								
								docs/docs/guides/template-backup-script.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										82
									
								
								docs/docs/guides/template-backup-script.md
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,82 @@ | |||||||
|  | # Backup Script | ||||||
|  | 
 | ||||||
|  | [Borg](https://www.borgbackup.org/) is a feature-rich deduplicating archiving software with built-in versioning. We provide a template bash script that can be run daily/weekly as a [cron](https://wiki.archlinux.org/title/cron) job to back up your files and database. We encourage you to read the quick-start guide for Borg before running this script. | ||||||
|  | 
 | ||||||
|  | This script assumes you have a second hard drive connected to your server for on-site backup and ssh access to a remote machine for your third off-site copy. [BorgBase](https://www.borgbase.com/) is an alternative option for off-site backups with a competitive pricing structure. You may choose to skip off-site backups entirely by removing the relevant lines from the template script. | ||||||
|  | 
 | ||||||
|  | The database is saved to your Immich upload folder in the `database-backup` subdirectory. The database is then backed up and versioned with your assets by Borg. This ensures that the database backup is in sync with your assets in every snapshot. | ||||||
|  | 
 | ||||||
|  | ### Prerequisites | ||||||
|  | 
 | ||||||
|  | - Borg needs to be installed on your server as well as the remote machine. You can find instructions to install Borg [here](https://borgbackup.readthedocs.io/en/latest/installation.html). | ||||||
|  | - To run this sript as a non-root user, you should [add your username to the docker group](https://docs.docker.com/engine/install/linux-postinstall/). | ||||||
|  | - To run this script non-interactively, set up [passwordless ssh](https://www.redhat.com/sysadmin/passwordless-ssh) to your remote machine from your server. | ||||||
|  | 
 | ||||||
|  | To initialize the borg repository, run the following commands once. | ||||||
|  | 
 | ||||||
|  | ```bash title='Borg set-up' | ||||||
|  | UPLOAD_LOCATION="/path/to/immich/directory"       # Immich database location, as set in your .env file | ||||||
|  | BACKUP_PATH="/path/to/local/backup/directory" | ||||||
|  | 
 | ||||||
|  | mkdir "$UPLOAD_LOCATION/database-backup" | ||||||
|  | mkdir "$BACKUP_PATH/immich-borg" | ||||||
|  | 
 | ||||||
|  | borg init --encryption=none "$BACKUP_PATH/immich-borg" | ||||||
|  | 
 | ||||||
|  | ## Remote set up | ||||||
|  | REMOTE_HOST="remote_host@IP" | ||||||
|  | REMOTE_BACKUP_PATH="/path/to/remote/backup/directory" | ||||||
|  | 
 | ||||||
|  | ssh "$REMOTE_HOST" "mkdir $REMOTE_BACKUP_PATH/immich-borg" | ||||||
|  | ssh "$REMOTE_HOST" "borg init --encryption=none $REMOTE_BACKUP_PATH/immich-borg" | ||||||
|  | ``` | ||||||
|  | 
 | ||||||
|  | Edit the following script as necessary and add it to your crontab. Note that this script assumes there are no spaces in your paths. If there are spaces, enclose the paths in double quotes. | ||||||
|  | 
 | ||||||
|  | ```bash title='Borg backup template' | ||||||
|  | #!/bin/sh | ||||||
|  | 
 | ||||||
|  | # Paths | ||||||
|  | UPLOAD_LOCATION="/path/to/immich/directory" | ||||||
|  | BACKUP_PATH="/path/to/local/backup/directory" | ||||||
|  | REMOTE_HOST="remote_host@IP" | ||||||
|  | REMOTE_BACKUP_PATH="/path/to/remote/backup/directory" | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | ### Local | ||||||
|  | 
 | ||||||
|  | # Backup Immich database | ||||||
|  | docker exec -t immich_postgres pg_dumpall -c -U postgres | /usr/bin/gzip > $UPLOAD_LOCATION/database-backup/immich-database.sql.gz | ||||||
|  | 
 | ||||||
|  | ### Append to local Borg repository | ||||||
|  | borg create $BACKUP_PATH/immich-borg::{now} $UPLOAD_LOCATION --exclude $UPLOAD_LOCATION/thumbs/ --exclude $UPLOAD_LOCATION/encoded-video/ | ||||||
|  | borg prune --keep-weekly=4 --keep-monthly=3 $BACKUP_PATH/immich-borg | ||||||
|  | borg compact $BACKUP_PATH/immich-borg | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | ### Append to remote Borg repository | ||||||
|  | borg create $REMOTE_HOST:$REMOTE_BACKUP_PATH/immich-borg::{now} $UPLOAD_LOCATION --exclude $UPLOAD_LOCATION/thumbs/ --exclude $UPLOAD_LOCATION/encoded-video/ | ||||||
|  | borg prune --keep-weekly=4 --keep-monthly=3 $REMOTE_HOST:$REMOTE_BACKUP_PATH/immich-borg | ||||||
|  | borg compact $REMOTE_HOST:$REMOTE_BACKUP_PATH/immich-borg | ||||||
|  | ``` | ||||||
|  | 
 | ||||||
|  | ### Restoring | ||||||
|  | 
 | ||||||
|  | To restore from a backup, use the `borg mount` command. | ||||||
|  | 
 | ||||||
|  | ```bash title='Restore from local backup' | ||||||
|  | BACKUP_PATH="/path/to/local/backup/directory" | ||||||
|  | mkdir /tmp/immich-mountpoint | ||||||
|  | borg mount $BACKUP_PATH/immich-borg /tmp/immich-mountpoint | ||||||
|  | cd /tmp/immich-mountpoint | ||||||
|  | ``` | ||||||
|  | 
 | ||||||
|  | ```bash title='Restore from remote backup' | ||||||
|  | REMOTE_HOST="remote_host@IP" | ||||||
|  | REMOTE_BACKUP_PATH="/path/to/remote/backup/directory" | ||||||
|  | mkdir /tmp/immich-mountpoint | ||||||
|  | borg mount $REMOTE_HOST:$REMOTE_BACKUP_PATH/immich-borg /tmp/immich-mountpoint | ||||||
|  | cd /tmp/immich-mountpoint | ||||||
|  | ``` | ||||||
|  | 
 | ||||||
|  | You can find available snapshots in seperate sub-directories at `/tmp/immich-mountpoint`. Restore the files you need, and unmount the Borg repository using `borg umount /tmp/immich-mountpoint` | ||||||
| @ -61,6 +61,12 @@ You can select the Jobs tab to see Immich processing your photos. | |||||||
| 
 | 
 | ||||||
| <img src={require('../guides/img/jobs-tab.png').default} title="Jobs tab" /> | <img src={require('../guides/img/jobs-tab.png').default} title="Jobs tab" /> | ||||||
| 
 | 
 | ||||||
|  | ## Set up your backups | ||||||
|  | 
 | ||||||
|  | You may want to back up the content of your Immich instance | ||||||
|  | along with other parts of your server; be sure to read about | ||||||
|  | [database backup](../administration/backup-and-restore). | ||||||
|  | 
 | ||||||
| ## Where to go from here? | ## Where to go from here? | ||||||
| 
 | 
 | ||||||
| You may decide you'd like to install the server a different way; | You may decide you'd like to install the server a different way; | ||||||
| @ -79,7 +85,3 @@ there's a [Guide](../guides/external-library) for that. | |||||||
| 
 | 
 | ||||||
| You may want your mobile device to | You may want your mobile device to | ||||||
| [back photos up to your server automatically](../features/automatic-backup). | [back photos up to your server automatically](../features/automatic-backup). | ||||||
| 
 |  | ||||||
| You may want to back up the content of your Immich instance |  | ||||||
| along with other parts of your server; be sure to read about |  | ||||||
| [database backup](../administration/backup-and-restore). |  | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user