Caution
READ CAREFULLY! When using Chroot environments to exit completely close the Termux application even from the background apps or if necessary force close it. Otherwise, in case you do some command like "rm -rf chrootFolder" the device will go crazy and you will have to force reboot it.
- 🏁 First steps
- 💻🟠 Setting Ubuntu chroot
- ⬇️ Download Ubuntu chroot
- 🎨 Customizations (Nerdfonts, XFCE4 terminal color palettes, etc)
Note
All the process is described in this video (outdated).
- First you need to have your device rooted.
- You need to flash Busybox NDK with Magisk or if you use kernelSU you may use it's bundled busybox binary.
- Then you need to install the following packages in Termux:
pkg update \
&& pkg install x11-repo root-repo \
&& pkg install termux-x11-nightly sudo pulseaudio wget
These steps are from Ivon's blog but I've modified some of the lines. These are the post used:
- Install Ubuntu in chroot on Android without Linux Deploy
- How to use Termux X11 - The X server on Android phone
- Enter Android shell with root privileges:
su
- Create a directory at
/data/localfor chroot environment and fix potential permission issues
mkdir -p /data/local/chroot/ubuntu
chmod 755 /data/local/chroot/ubuntu
chown root:root /data/local/chroot/ubuntu
cd /data/local/chroot/ubuntu
- Download Ubuntu 24.04 LTS rootfs:
curl https://cdimage.ubuntu.com/ubuntu-base/releases/24.04/release/ubuntu-base-24.04.4-base-arm64.tar.gz -o ubuntu.tar.gz
- Extract the downloaded file and create sdcard folder
tar xpvf ubuntu.tar.gz --numeric-owner
mkdir -p sdcard
- Create startup script:
cd ..
busybox vi start_ubuntu.sh
Copy and paste the following:
#!/bin/sh
# The path of Ubuntu rootfs
UBUNTUPATH="/data/local/chroot/ubuntu"
# Fix setuid issue
busybox mount -o remount,dev,suid /data
busybox mount --bind /dev $UBUNTUPATH/dev
busybox mount --bind /sys $UBUNTUPATH/sys
busybox mount --bind /proc $UBUNTUPATH/proc
busybox mount -t devpts devpts $UBUNTUPATH/dev/pts
# /dev/shm for Electron apps
mkdir -p $UBUNTUPATH/dev/shm
busybox mount -t tmpfs -o size=256M tmpfs $UBUNTUPATH/dev/shm
# Mount sdcard
busybox mount --bind /sdcard $UBUNTUPATH/sdcard
# chroot into Ubuntu
busybox chroot $UBUNTUPATH /bin/su - root
- Make the script executable and run it:
chmod +x start_ubuntu.sh
sh start_ubuntu.sh
- The prompt will change to
root@localhost. If you need to return to Termux just writeexit. Let's perform some fixes:
echo "nameserver 8.8.8.8" > /etc/resolv.conf
echo "127.0.0.1 localhost
::1 localhost" > /etc/hosts
groupadd -g 3003 aid_inet
groupadd -g 3004 aid_net_raw
groupadd -g 1003 aid_graphics
usermod -g 3003 -G 3003,3004 -a _apt
usermod -G 3003 -a root
apt update && apt upgrade
apt install nano vim net-tools sudo git
- Set timezone. The interactive shell should prompt you to select your timezone if it doesn't run this:
dpkg-reconfigure tzdata
- Create a new user called
droidmaster(or the name you prefer):
groupadd storage
groupadd wheel
useradd -m -g users -G wheel,audio,video,storage,aid_inet -s /bin/bash droidmaster
passwd droidmaster
- Add the created user to sudoers file to have superuser privileges:
visudo
Add this line (replace droidmaster with your prefered name):
droidmaster ALL=(ALL:ALL) ALL
- Switch to the created user:
su - droidmaster
And generate locales:
sudo apt install locales
sudo locale-gen en_US.UTF-8
- Install Desktop Environment:
- XFCE4
sudo apt install xubuntu-desktop
- KDE Plasma
sudo apt install kubuntu-desktop
- Disable Snapd (it can't be used on Termux):
sudo apt-get autopurge snapd
cat <<EOF | sudo tee /etc/apt/preferences.d/nosnap.pref
# To prevent repository packages from triggering the installation of Snap,
# this file forbids snapd from being installed by APT.
# For more information: https://linuxmint-user-guide.readthedocs.io/en/latest/snap.html
Package: snapd
Pin: release a=*
Pin-Priority: -10
EOF
- Exit chroot and modify the
start_ubuntu.shscript created on step5:
vi /data/local/chroot/start_ubuntu.sh
Comment the last line busybox chroot $UBUNTUPATH /bin/su - root and write the following line under it:
busybox chroot $UBUNTUPATH /bin/su - droidmaster -c "export DISPLAY=:0 PULSE_SERVER=tcp:127.0.0.1:4713 && dbus-launch --exit-with-session startxfce4"
If you've installed a different Desktop Environment you need to replace startxfce4. For example for KDE Plasma you should replace startxfce4 with startplasma-x11.
- Let's run the Desktop Environment. Exit chroot environment and download the script with wget and start it on Termux (you can close everything and reopen Termux to be sure you are outside chroot).
wget https://raw.githubusercontent.com/LinuxDroidMaster/Termux-Desktops/refs/heads/main/scripts/chroot/ubuntu/startxfce4_chrootubuntu.sh
chmod +x startxfce4_chrootubuntu.sh
./startxfce4_chrootubuntu.sh
- Download Ubuntu 24.04 rootfs:
curl https://cdimage.ubuntu.com/ubuntu-base/releases/24.04/release/ubuntu-base-24.04.4-base-arm64.tar.gz -o ubuntu.tar.gz
- Note if you want to use firefox use the apt repository it's recommended Firefox.
-
XFCE4 color palettes:
-
Installing NerdFonts on chroot env (Debian, Ubuntu) from this post:
sudo apt install wget unzip -y
wget -P ~/.local/share/fonts https://github.com/ryanoasis/nerd-fonts/releases/download/v3.0.2/JetBrainsMono.zip \
&& cd ~/.local/share/fonts \
&& unzip JetBrainsMono.zip \
&& rm JetBrainsMono.zip \
&& fc-cache -fv