Backing up Termux

= Backup and restore Termux installation =

Here we will use a tool called Restic. This utility offers secure incremental backups and ability to save backups on the remote machine as well as on local.

Backing up Termux installation ($PREFIX). Following steps do not include backup of your $HOME.

1. Install restic. For now, it is located in the "unstable" repository (though, restic is very stable in Termux):

pkg install restic

2. In this example will be shown how to backup Termux to the local storage. Initializing local restic repository (you will be prompted for password):

mkdir -p /sdcard/termux-backups restic init -r /sdcard/termux-backups

3. Backing up current Termux installation ($PREFIX):

restic backup -r /sdcard/termux-backups --tag termux $PREFIX

Note that you will be prompted for password entered in step 2. Here we created tag "termux" so later it will be easier to distinguish snapshot purposes in case if you have multiple backups in repository. Restic does backups in incremental mode with deduplication - this makes backups take less space and finish faster.

If you need to backup Termux again, simply re-run command from the step 3.

Restoring Termux installation is more complicated. If you need to do this, follow next steps (applicable only for local backups).

1. Make sure that restic is available:

pkg install unstable-repo pkg install restic

2. Since we will remove $PREFIX, copy restic to $HOME - it is a portable binary and doesn't require any dependencies (except Android):

cp $PREFIX/bin/restic $HOME/restic

3. Unset LD_PRELOAD (disable termux-exec):

unset LD_PRELOAD

4. Remove old $PREFIX:

rm -rf $PREFIX

5. Restore Termux from backup:

$HOME/restic restore -r /sdcard/termux-backups --tag termux --target / latest

If everything done right, you should now have a Termux restored from the backup.

Info: if you do not want to enter restic password or specify repository each time, you can set environment variables "RESTIC_PASSWORD" and "RESTIC_REPOSITORY".