Backing up Termux

On this page you will find some methods of backing up and restoring your Termux installation.

It is highly recommended to understand what commands listed here do before copy-pasting them. Misunderstanding purpose of each step may irrecoverably damage your data, if that happened to you - do not complain.

With tar
Archiving sysroot and home directories is the simplest way to backup your data. Such method doesn't require any additional packages as needed utilities are already provided by busybox.

Backing up
In this example a backup of both home and sysroot will be shown. The resulting archive will be stored on your shared storage and compressed with.

1. Ensure that storage permission is granted:

termux-setup-storage

2. Go to Termux base directory:

cd /data/data/com.termux/files

3. Backing up files:

tar -zcvf /sdcard/termux-backup.tar.gz home usr

Backup should be finished without any error. There shouldn't be any permission denials, unless user abused root permissions. Warnings about sockets are okay.

Warning: never store your backups in Termux private directories. Their paths may look like:

/data/data/com.termux                      - private Termux directory on internal storage /sdcard/Android/data/com.termux            - private Termux directory on shared storage /storage/XXXX-XXXX/Android/data/com.termux - private Termux directory on external storage, XXXX-XXXX is the UUID of your micro-sd card. ${HOME}/storage/external-1                 - alias for Termux private directory on your micro-sd.

Once you clear Termux data from settings, these directories will be erased too. Unconditionally.

Restoring
Instructions for home directory and usr (sysroot or prefix) are separate, though if you did backup in way shown above, these directories stored in same archive.

There also will be assumed you have granted access to shared storage and your archive is stored at.

By following these instructions all your Termux files will be overwritten with ones from back up.

Home directory
Just follow steps listed here:

1. Go to Termux base directory:

cd /data/data/com.termux/files

2. Replace home directory with one from your backup:

rm -rf home usr tar -zxvf /sdcard/termux-backup.tar.gz

Home directory isn't runtime-critical, no additional steps like closing/re-opening Termux required.

Sysroot (prefix)
Restoring of sysroot is quite complicated. You will have to delete  where all package data is stored.

1. Go to Termux base directory:

cd /data/data/com.termux/files

2. Copy busybox binary in way shown here (important !):

cp ./usr/bin/busybox ./tar

3. Erase sysroot. At this point all packages will be deleted.

rm -rf usr

4. Restore sysroot from backup:

unset LD_PRELOAD ./tar -zxvf /sdcard/termux-backup.tar.gz usr

Now close Termux with "exit" button from notification and open it again.

With restic
Restic is an utility for doing incremental backups. It can work with both local and remote backups. Backed up data is encrypted and de-duplicated.

This package is not available by default. Install it with following command:

pkg install restic

Notice: restic is for advanced users only. While it provides more features than, it is harder in use. Most people will use it in scripts rather than manually in command line. Instructions here provided only as example.

Sample restic-powered backup script for Termux: https://gist.github.com/xeffyr/42cbfe0e66f912e4622108329390eb3d

Backing up
These steps will backup only sysroot (prefix) and not your home. Repository will be stored on shared storage.

1. Initialize local restic repository. You will be prompted for password because encryption is enabled (no way to turn off). If password is lost - your data will be locked forever.

restic init -r /sdcard/termux-backups

2. Backing up sysroot ($PREFIX):

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

Tag is not necessary, but will be useful in case if you decide to backup multiple directories into same repository. For example, you can backup home directory in this way:

restic backup -r /sdcard/termux-backups --tag termux-home $HOME

Restoring
Same as with tar-based backups, restoring of sysroot is tricky. Following steps are applicable only for local backups:

1. Make sure that restic is available:

pkg install restic

2. Copy restic binary to $HOME. We are going to erase sysroot.

cp $PREFIX/bin/restic $HOME/restic

3. Erase sysroot. All packages will be deleted.

rm -rf $PREFIX

4. Restore sysroot from latest snapshot:

unset LD_PRELOAD $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. Close your Termux application and open it again.

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