Remote Access

Termux is capable of accessing remote devices by using some common tools. It is also possible to turn a device running Termux into remote controlled server.

= FTP =

Termux provides a lightweight FTP server so you can manage your files via remote connection. FTP server is provided by busybox package, so you don't have to install anything.

To start FTP server you have to run `ftpd` via `tcpsvd`:

$ tcpsvd -vE 0.0.0.0 1024 ftpd /

Command shown above will start FTP server on port 1024 from the root (`/`) directory.

By default, ftpd is started in read-only mode, e.g. you can only download files or perform directory listing. If you want to upload files, then ftpd should be started in this way:

$ tcpsvd -vE 0.0.0.0 1024 ftpd -w /

Then you can connect to Termux from another device. Example for connecting to Termux with command line FTP client (from PC):

$ ftp 192.168.1.3 1024

You shouldn't start FTP on port lower than 1024 otherwise this will result in the following error message:

tcpsvd: bind: Permission denied

Security warning: this FTP server supports only anonymous login, so there is no authentication and anyone can connect to your device and do nasty things. Use it only in your own network or use SFTP instead.

= SSH =

SSH provides secure way for accessing remote hosts and replaces tools such as telnet, rlogin, rsh, ftp. Termux provides SSH via two packages: dropbear and openssh. If you never used these tools before, it is recommended to install 'openssh' as it is more common.

Using the SSH client
By installing the openssh package (by executing apt install openssh) you may SSH into remote systems, optionally putting private keys or configuration under $HOME/.ssh/.

If you wish to use an SSH agent to avoid entering passwords, the Termux openssh package provides a wrapper script named ssha (note the ‘a’ at the end) for ssh which:


 * 1) Starts the ssh agent if necessary (or connect to it if already running).
 * 2) Runs ssh-add if necessary.
 * 3) Runs ssh with the provided arguments.

This means that the agent will prompt for a key password at first run, but remember the authorization for subsequent runs.

Using the SSH server
The sshd server is included in the openssh package and allows you to connect to your Android device over ssh.

Start the server by executing `sshd` (which will start it on the default port 8022) and run `logcat -s 'syslog:*'` to view the log output from the server process. Execute `pkill sshd` to stop the server.

Since Termux is a single-user system you may connect as any user - regardless of your specified username you will login as the only Termux user available.

The Termux sshd binary does not support password logins, so a key needs to be authorized in `~/.ssh/authorized_keys` before connecting. Use `ssh-keygen` to generate a new one if desired.

Using the SFTP
Package OpenSSH provides a tool for accessing remote hosts over SFTP. This will allow you to work with files in same way as via FTP but with better security.

Connecting to Termux (sshd listening on port 8022):

$ sftp -P 8022 192.168.1.20

Connecting to somewhere else (sshd listening on standard port):

$ sftp sftp.example.com

However, to use command line SFTP client you should know some basic commands:


 * cd PATH - change current directory to 'PATH'.
 * get REMOTE [LOCAL] - download file 'REMOTE' and rename it as 'LOCAL' (optional).
 * mkdir PATH - create directory 'PATH'.
 * ls [PATH] - list files in directory 'PATH'. If no argument, files in current directory will be listed.
 * put LOCAL [REMOTE] - Upload file 'LOCAL' and rename it as 'REMOTE' (optional).
 * rm FILE - Delete file 'FILE'.

This is not a complete list of SFTP commands. To view all available commands, consider to view man page (`man sftp`) or view short help in interactive SFTP session by issuing command `help`.

= MOSH = Mosh is a remote terminal application that allows roaming, supports intermittent connectivity, and provides intelligent local echo and line editing of user keystrokes.

Usage examples:


 * Connecting to remote host (sshd listening on standard port):

mosh user@ssh.example.com


 * Connecting to Termux (sshd listening on port 8022):

mosh --ssh="ssh -p 8022" 192.168.1.25

Note: Mosh should be installed on both client and server side.

= Rsync =

Rsync is a tool for synchronizing files with remote hosts or local directories (or drives). For better experience of using rsync, make sure that package `openssh` is installed.

Some usage examples:


 * Sync your photos with PC:

$ rsync -av /sdcard/DCIM/ user@192.168.1.20:~/Pictures/Android/


 * Get photos from remote Android device:

$ rsync -av -e 'ssh -p 8022' 192.168.1.3:/sdcard/DCIM/ /sdcard/DCIM/


 * Sync local directories (e.g. from external sdcard to Termux home):

$ rsync -av /storage/0123-4567/myfiles ~/files

You may want to see man page (`man rsync`) to learn more about it's usage.

= Accessing Termux from the Internet =

It is possible to access your device over the Internet even if you are behind NAT device (e.g. Wi-Fi router or on mobile network). There are some ways to achieve this, but will require installing additional software and a bit of configuration.

Tor
Accessing device via Tor is the most secure and effective method - offers strong end-to-end encryption (onion services don't use 'exit' node), virtual ports (e.g. 80 port without root), your service won't be visible on plain Internet.

However, this method requires setting up a Tor Onion Service.

Installing needed packages
The main package is tor. Install it by running this command: pkg install tor

You may want to install a `torsocks` for accessing the Tor Network: pkg install torsocks

Setting up Onion Service
You will have to modify the default configuration file of tor. Here is an example of configuring SSH Onion Service: SOCKSPort 127.0.0.1:9050
 * 1) Enable TOR SOCKS proxy

HiddenServiceDir /data/data/com.termux/files/home/.tor/hidden_ssh HiddenServicePort 22 127.0.0.1:8022
 * 1) Hidden Service: SSH

Then you need to make a directory where information about Hidden Service will be stored: mkdir -p ~/.tor/hidden_ssh

Now you can execute in console. If start was successfull, you can get your onion service hostname: cat ~/.tor/hidden_ssh/hostname Output should be like this:

Accessing your service
First of all make sure that on client device `tor` is running and you have all necessary software for accessing Tor Network (in this case package `torsocks`).

To access the onion service created in previous step, run this: torsocks ssh g3yv3tvqrbow7koz.onion

If everything is ok, the output should be like this: The authenticity of host 'g3yv3tvqrbow7koz.onion (127.42.42.0)' can't be established. ED25519 key fingerprint is SHA256:WGualHEq7SJdvVeXgy8a+btPQCd7uxTeXjlWdHHLwLc. Are you sure you want to continue connecting (yes/no)?

Remember, `tor` should be running on both (client/server) sides, otherwise you will get connection errors. You can configure other servers (e.g. Nginx) in the same way as shown in above example for SSH.

Learn more about Onion Services
Better explanation about Onion Services and other Tor-related things you can found at torproject.org.

Ngrok
Ngrok is a service for exposing your local services on Internet. Software is closed source, but still available for Termux. Service is paid, but has a free plan with restrictions.

Serveo.net
A free service for exposing your local services on Internet. Uses SSH.

= See Also =

https://termux.com/ftp/ Run an SSH server on your Android with Termux