Backing up Termux

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

Notice: 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 Termux's sysroot or home is the simplest way to backup your data. Such method doesn't require additional packages since needed utilities already provided by busybox.

Backing up
In this example a backup of both home and sysroot will be shown.

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

Restoring Termux from tar archive
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 tar -zxvf /sdcard/termux-backup.tar.gz home

Sysroot (prefix)
Restoring of sysroot is quite complicated since 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
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".