FAQ

What is Termux?
Termux is a terminal emulator for Android. It can be considered to be more like a Linux distribution than just a terminal application due to a large number of available packages such as clang, FFmpeg, OpenSSH, Python, Vim.

Termux is not an OS or hardware emulator. It shares the same environment as other parts of the Android OS. For better understanding about what's going on, it is suggested to read the following articles:


 * Wikipedia: what is a terminal emulator
 * How different Termux is from Linux distribution

Where can I get help with Termux?
This Wiki is a good start on the basics of Termux. Other options include:


 * IRC: Channel #Termux on freenode that is mirrored with Gitter.
 * Github: Submit bug reports regarding the main app, packages, and addons. Create pull requests for your solutions.
 * Gitter: Chatroom that is mirrored with IRC.
 * Reddit: Reddit community, ask general questions here.

More links can be found at Community page.

Consider researching Termux on the Internet too, e.g. Termux site:github.com

Can I contribute?
Yes, contributions are welcome. Termux is an open source application and it is built on users' contributions.

The source code repositories for all components can be found on project's page on Github. Developer's documentation available at https://github.com/termux/termux-packages/wiki.

If you want to request a particular package or submit a bug report, please, open an issue in one of the following repositories:


 * Application-related issues: https://github.com/termux/termux-app/issues
 * Package-related issues: https://github.com/termux/termux-packages/issues

Please do not submit any issues about third-party content.

Can Termux be installed on Android 4?
No, it cannot be installed.

There multiple reasons for this. The first one is format of executable files - Android 5 and higher requires ELF binaries to use position independent code as part of security hardening. This type of binaries is not supported on lower Android versions. The second reason is Bionic libc which on lower Android version lacks a lot of common functions used by command line applications.

It also worth to state that maintaining multiple versions of packages in order to have them working properly on lower Android versions put more load on maintainers and also old Android versions known to have many more OS bugs which should be worked-around on Termux side.

Termux is no longer available for Android 5?
As of 01.01.2020, the support for Android 5.x and 6.x was dropped for reasons similar to Android 4. You can still use Termux on old devices, but package updates will not be available and Termux developers are no longer interested in fixing issues for old Android versions.

APKs, packages and their source code compatible with Android 5 are available on the Internet Archive.

What is a Termux legacy environment?
Generally, it is all packages compiled for Android 5.x - 6.x and served on https://termux.net. So if your Termux installs packages for this repository - you are out of support since 01.01.2020.

If you for some reason have "legacy environment" on Android 7 and higher, do repository switching with the next command:

termux-upgrade-repo

This utility will erase everything under $PREFIX (place where packages are installed) but will not touch anything in Termux home directory. On finish it will create a package reinstallation script and prompt you to restart Termux application.

Android 5/6 users are not able to use this script. Attempts to cheat and switch to mainline repository on OS versions below 7.0 will lead to complete environment breakage.

What can I use Termux for?
Termux is general purpose utility and in theory can be used for everything that can be done on typical Linux distribution.

Sample use cases:


 * Learning the basics of Linux command line environment.
 * Development environment.
 * File synchronization or Web server.
 * SSH client.
 * Downloading and managing files and pages using time-established tools.
 * Data processing using Python.

Of course there are many more things for which Termux is used for. We have more than 950 packages in our repositories and you can even compile your own, so questions of usability should not be a problem.

For users who are new to shell scripting, it will be better to start with learning Bash and probably will be worth to check these articles on Termux Wiki:


 * Development Environments
 * Editors
 * Differences from Linux
 * Package Management
 * Software

Is Termux a complete Linux environment?
Yes, it is.

But it is not a traditional Linux distribution. First of all Termux is not an operating system. It is a terminal emulator application - a text-based interface for representing standard input, output and error streams of the program which is typically a shell script interpreter. Secondly, it shares same file system tree with Android and due to this it cannot have own root file system and follow the FHS standard. You will not find /bin, /usr, /home directories on their standard place. Instead, Termux root file system is prefixed (and usually referred to as $PREFIX) and available under the following constant path:

/data/data/com.termux/files/usr

The home directory (typically referred to as $HOME) is under:

/data/data/com.termux/files/home

This makes a lot of difference during package installation and compilation where the FHS directory structure is expected.

See this discussion and for more directory structure and $PREFIX environment information.

Can I use Termux for hacking?
Yes, you can, but this is more a question of your skills rather than Termux features.

We have some tools which may (or may not) help you in penetration testing. For example: aircrack-ng (set of utilities for Wi-Fi security audit), hydra (brute force tool), metasploit (platform for testing against known vulnerabilities) or nmap (port scanner). Various development tools like clang and python are available too.

Certain tools like aircrack-ng require your device to be rooted and/or even run a custom Linux kernel with additional drivers and patches.

A letter to Termux "hackers": We are not helping with hacking. No matter for which purpose you need it - we do not care about your learning needs and dirty mind. Just do not ask about hacking Facebook, Instagram, Whatsapp, Telegram and whatever else. And do not ask about rooting your device - our community is not XDA forum !

A letter to hacking tutorial seekers: Beware of scripts suggested to be executed in various "hacking tutorials" available on the Internet. Most of them actually do not work properly (outdated ?). Some of them break Termux environment or even installs malware. Termux developers are not responsible about any damage which may happen by following these "tutorials".

How do I access the device storage in Termux?
You need to grant storage permission to Termux application.

Open Android settings and go to Apps>Termux>Permissions and toggle the storage permission in menu. You may request this permission directly from Termux command line, just execute

termux-setup-storage

and grant the requested permission.

More information is available in Internal and external storage.

Can Termux be installed on the external SD card?
No, it cannot be installed there.

External SD cards are usually formatted in FAT32 or exFAT. These file systems do not support features such as symbolic links and Unix permissions. Program execution is not supported due to  mount option. Moreover, Android applies a special overlay which enforces mentioned restrictions regardless of underlying file system.

Why will Termux not write to an external SD card?
Android disallows arbitrary write access to external volumes. You can write only to private directory on such storage whicn is usually accessible through paths like

/storage/XXXX-XXXX/Android/data/com.termux

Alternate solution will be only root or custom ROMs which have this restriction disabled.

We received suggestions for using Storage Access Framework which is used by file managers. But it is not suitable for Termux: command line binaries are standalone and executed outside of Android runtime context and therefore SAF access cannot be passed to them.

Why does Termux not support more special buttons?
Their support is available but is not configured by default.

Check the Touch Keyboard Wiki article to learn about how to configure extra keys row and some key combinations.

Why might Termux add-on installation fail?
Since Termux environment is shared between all its add-ons, each APK must be signed with same key. Unfortunately, we cannot use same signature key for various installation sources.

Thus if Termux application was installed from Google Play, you will not be able to install add-on from F-Droid and vice versa.

How do I get help for a specific package?
Usually  will display basic help for an application.

Advanced information about program usage can be viewed through  tool. It can be installed with. Typing commands  or   can help beginning and advanced users alike. For example,  will output the manual page for the package 'busybox'.

Tips, when reading a man page:
 * Use q to quit
 * Use space for next page
 * /search for search
 * n for repeat search

How do I downgrade a package?
Termux uses "rolling-release" update scheme so downgrading is not supported.

We may provide older versions for some packages, but due to technical reasons and do not rely on them. Older versions may be removed from APT repository at any time.

The optimal way for downgrading packages would be compiling it on your own.

Where are all the *-dev packages?
In Termux they are not needed because development files are not split from the main package. Now, for example instead of libxml2-dev you will need just libxml2.

Can I use packages from another Debian repository?
No, you can't.

There are major differences between Termux and regular Linux distributions and packages from these repositories won't work. See Differences from Linux for more information.

It is better to try request it in termux-packages/issues on Github.

Can I run other Linux distributions in Termux?
Yes, with  utility you will be able to create and use chroot environment even if device is not rooted.

Please read the PRoot for more information.

Why might apt fail when executed as root?
Apt is now patched to prevent execution as root. We have the next reasons to do so:
 * Running apt as root will mess up ownership and SELinux labels in $PREFIX.
 * Some packages use hooks running during installation or deletion. There is small probability that script may fail and cause massive ownership corruption or even data loss (including device soft bricking) if executed under root.

Can I use Termux packages in my own project?
Yes, you can but with following restrictions:


 * Your project must comply with license of Termux part you want to reuse.
 * Your project should not reuse our APT repository - our bandwidth is limited.

All binaries have some Termux-specific paths hardcoded. If your project is going to use a different application package name, you will have to recompile all necessary packages and their dependencies.

Get started with information on developer's wiki pages: https://github.com/termux/termux-packages/wiki.

Why do I keep getting a '/bin/sh bad interpreter' error?
This error is thrown due to access script interpreter at nonexistent location.

Termux does not have common directories like /bin, /sbin, /usr/bin at their standard place. There is an exception for certain devices where /bin is a symbolic link to /system/bin, but that does not make a difference.

Interpreters should be accessed at this directory only:

/data/data/com.termux/files/usr/bin

There are three ways to fix this:


 * Install termux-exec by using . It won’t affect the current session, but after a restart should work without any setup. Not needed if your Termux is up to date. If still not working, try the next workaround.
 * Use command  to fix the shebang line of specified file.
 * Use  from package proot to setup a chroot environment mimicking a normal Linux file system in Termux.

Why does a script finish with "permission denied"?
This error means file is not allowed for execution. For example, executable bit is not set or you are trying to execute it from a file system where  mount option is applied.

Try the following:


 * If file is located in $HOME or $PREFIX, execute  on it.
 * If file is on /sdcard (/storage/emulated/0), move it to $HOME and apply read & executable attribute like shown above. Otherwise execute file with interpreter, for example.

Why does a compiled program show warnings about DT_FLAGS_1=0x8?
This warning is completely safe and just notifies developer that linker detected unused extra information inside executable file. In case of DT_FLAGS_1=0x8, it warns about RTLD_NODELETE ELF section. Besides DT_FLAGS_1=0x8, there more types of ELF sections which are not handled by Android linker.

To make this warning disappear you need to use utility "termux-elf-cleaner" binary file and probably on all its dependencies.

pkg install termux-elf-cleaner termux-elf-cleaner ./myprogram ./libmysharedlibrary.so

Number of supported ELF sections increases with Android OS version. On Android 7.0 and higher you are unlikely to get linker warnings.

Why does an executable throw an 'Exec format error'?
You are trying to execute binary compiled for the different CPU architecture. For example, it is not possible to run x86 binary on ARM and vice versa.

If you have the source code for your binary, try to recompile it with Android NDK to CPU architecture of your device which can be checked with.

If binary is closed source or you cannot get it successfully compiled, try the QEMU in user mode. In order to run x86 binary, install the package  (if 32 bit) or   (if 64 bit). Then try to execute your binary under QEMU in way like.

Why does an executable throw the 'No such file or directory' error even though the file exists?
You are trying to execute binary compiled for desktop Linux distribution. Such binaries are dynamically linked against GNU or Musl libc and are incompatible with Android OS. They have hardcoded linker path which do not exist on Android and kernel terminates program with ENOENT (file not found) error code.

How do I fix a broken environment?
You can start a failsafe shell through application shortcut and try to repair from there. You will not have access to Termux utilities until these environment variables are set:

export PREFIX=/data/data/com.termux/files/usr export PATH=${PATH}:${PREFIX}/bin

In cases where environment was broken due to package manager failure or deletion of some important files, the easiest way of recovery will be to delete whole $PREFIX, restart Termux application and install packages from scratch.

More information available in Recover a broken environment.

How can I keep my data when reinstalling Termux?
Usually there is no need to reinstall Termux. Just  and restart application - this will not touch the content of $HOME.

If you really want to reinstall application, you can archive contents of $HOME and store it on shared storage (/sdcard). Follow instructions on article Backing up Termux.

How to run Termux commands from other application?
This is not supported currently.

That feature will not be implemented until Termux will have a solution for at least per-app access control.

Many users use it for accessing remote services and this requiring to store SSH keys, API tokens and other sensitive information in $HOME. Termux obviously do not have privilege separation and we need to somehow protect user's data from third party eyes.