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
Instructions for home directory and usr (sysroot or prefix) are separate, though if you did backup in the way shown above, these directories are stored in the 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 the 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 tar -zxvf /sdcard/termux-backup.tar.gz home

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

Sysroot (prefix)
The 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 the way shown here. You can't use any other archiver binary here as only busybox doesn't have the dependencies which will be gone in next step.

pkg install busybox 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 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".