Package Management

Termux uses apt and dpkg for package management, similar to Ubuntu or Debian. Many quirks from Ubuntu are carried over here. Development files (cmake files) and headers are provided in a separate package with "-dev" suffix. For example: development files for apache2 package are in apache2-dev package.

pgk and apt
By default Termux doesn't have a cron daemon running. Therefore Users generally need to run `apt update` themselves. This has caused a lot of confusion. As a result of this a wrapper script for apt, pkg, was implemented. It will call `apt update` automatically before trying to install something.

Installing Packages
Make sure that the local package index cache is up-to-date by running ( it is necessary to run this after installing the app ) :

To install apache2 web server:

Or you can use  wrapper, which updates the package cache before installing:

Manually downloaded .deb files (those from official Debian or Ubuntu repos won't work!) can be installed using:

or directly using :

Other Package Managers
Some programming languages have their own package manager. Everything that can be installed with such a manager isn't packaged with Termux, but should be available on-the-fly on device.


 * Node.js Package Management (npm)
 * Perl Package Management (cpan)
 * Python Package Management (pip)
 * Ruby Package Management (gem)
 * Texlive Package Management (tlmgr)

Community Repositories
In addition, to the official repository, there are other compatible Termux repositories too. You can create some yourself simply by using from the command line and Github and/or another host source for your repo.

its-pointless (live_the_dream)
This community member hosts a repository for Termux using GitHub Pages.

This repository includes,   (R language),  ,  ,  ,   and lots of games! To add this repository, execute:

curl -L https://its-pointless.github.io/setup-pointless-repo.sh | sh

The script essentially installs gnupg on your device and downloads and adds a public key to your apt keychain ensuring that all subsequent downloads are from the same source

Auxilus
This repository hosted by Auxilus contains some handy tools ( more tools are yet to be added )

You can add this repository by executing following commands There is a little under-development survival manual in this repo based on Field Manual FM 3-05.70, Which you can install using  after adding the repo pkg install apt-transport-https echo "deb [trusted=yes] https://Auxilus.github.io/files termux extras" >> $PREFIX/etc/apt/sources.list pkg update

cocodevienne
This community member host some pretty cool self written apps for python. This includes

Add this repo using pkg install apt-transport-https echo "deb [trusted=yes] http://cocodevienne.gitlab.io/aptpackages/termuxpackages termux extras" >> $PREFIX/etc/apt/sources.list pkg update

sdrausty's repositories
sdrausty hosts community repositories from an Android smartphone at Github Pages.

https://sdrausty.github.io/repo/ is one of the Termux community repositories hosted at sdrausty.github.io through Github Pages at Github.

You can add this repository by copying and pasting the next three command lines into the Termux window:

pkg install apt-transport-https

echo "deb [trusted=yes] https://sdrausty.github.io/repo termux extras" >> $PREFIX/etc/apt/sources.list

pkg update

This will allow  to access the repo repository at sdrausty.github.io from within Termux through   on your portable device.

At present this repository is set up for diagnostic purposes and your enjoyment. Please comment at https://github.com/sdrausty/repo/issues after adding it to your  file. To see what your  file contains, type   at the command prompt.

Package requests
Packages can be requested at https://github.com/termux/termux-packages/issues

Some dos before requesting a package:


 * Hardware requirements of the package is compatible for Android 5.0+ devices,


 * No other issues have been created for the same package request,


 * In case of interpreter based packages (python, ruby, etc...), the package is not easily installable using the custom package managers (pip, gem),


 * Packages requiring root privileges are generally discouraged, except if they can be patched to work under normal user,


 * Packages in active development are favoured over long dead projects.

Compiling packages
Packages for Termux are cross-compiled using build scripts (build.sh). These can be found here. To build a package, follow the instructions described in the README.md file from this repository.

All packages available in the official package repository are built under a docker container.

Backup and restore packages
Create a list of currently installed packages:

dpkg --get-selections | cut -f1 > mypackages.txt
 * 1) generate installed package list

Restore all packages from a previously created package list:

xargs -0 apt install -y < <(tr \\n \\0 < mypackages.txt)
 * 1) install packages

When using the commands from scripts it might be more convenient to use "$1" instead of mypackages.txt so that you can pass the file name as a command line argument.