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 the 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. You can install it using.

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 the 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
Here will be assumed that you have backed up both home and usr directory into same archive. Please note that all files would be overwritten during the process.

1. Go to Termux base directory:

cd /data/data/com.termux/files

2. Extract home and usr with overwriting everything and deleting stale files:

tar -zxf /sdcard/termux-backup.tar.gz --recursive-unlink --preserve-permissions

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

With restic
Restic is a 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 the 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 the command line. Instructions here provided only as an example.

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

1. Initialize local restic repository. You will be prompted for a password because encryption is enabled (no way to turn off). If the 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

A tag is not necessary but will be useful in case if you decide to backup multiple directories into the same repository. For example, you can backup  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 is 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 a restic password or specify repository each time, you can set environment variables "RESTIC_PASSWORD" and "RESTIC_REPOSITORY".