Deploy a Full VM and Run XRDP for Remote Desktop Connection
Table of Contents
- Introduction
- Server Side: Deploy the Full VM, install a desktop and XRDP
- Client Side: Install Remote Desktop Connection for Windows, MAC or Linux
- Conclusion
Introduction
In this guide, we learn how to deploy a full virtual machine on a 3node on the Threefold Grid. We access Ubuntu with a desktop environment to offer a graphical user interface (GUI).
This guide can be done on a Windows, MAC, or Linux computer. The only difference will be in the Remote Desktop app. The steps are very similar.
For more information on deploying a full VM and using SSH remote connection, read this SSH guide.
If you are new to the Threefold ecosystem and you want to deploy workloads on the Threefold Grid, read the Get Started section of the Threefold Manual.
Server Side: Deploy the Full VM, install a desktop and XRDP
-
Go to the Threefold Dashboard
-
Deploy a full VM (Ubuntu 20.04)
- With an IPv4 Address
-
After deployment, copy the IPv4 address
-
To SSH into the VM, write in the terminal
-
ssh root@VM_IPv4_address
-
-
Once connected, update, upgrade and install the desktop environment
- Update
-
sudo apt update -y && sudo apt upgrade -y
-
- Install a light-weight desktop environment (Xfce)
-
sudo apt install xfce4 xfce4-goodies -y
-
- Update
-
Create a user with root access
-
adduser newuser
-
ls /home
- You should see the newuser directory
- Give sudo capacity to newuser
-
usermod -aG sudo newuser
-
- Make newuser accessible by SSH
-
su - newuser
-
mkdir ~/.ssh
-
nano ~/.ssh/authorized_keys
- add authorized public key in file and save
-
- Exit the VM and reconnect with new user
-
exit
-
-
-
Reconnect to the VM terminal and install XRDP
-
ssh newuser@VM_IPv4_address
-
-
Install XRDP
-
sudo apt install xrdp -y
-
-
Check XRDP status
-
sudo systemctl status xrdp
- If not running, run manually:
-
sudo systemctl start xrdp
-
-
-
If needed, configure xrdp (optional)
-
sudo nano /etc/xrdp/xrdp.ini
-
-
Create a session with root-access user Move to home directory
- Go to home directory of root-access user
-
cd ~
-
- Go to home directory of root-access user
-
Create session
-
echo "xfce4-session" | tee .xsession
-
-
Restart the server
-
sudo systemctl restart xrdp
-
-
Find your local computer IP address
- On your local computer terminal, write
-
curl ifconfig.me
-
- On your local computer terminal, write
-
On the VM terminal, allow client computer port to the firewall (ufw)
-
sudo ufw allow from your_local_ip/32 to any port 3389
-
-
Allow SSH connection to your firewall
-
sudo ufw allow ssh
-
-
Verify status of the firewall
-
sudo ufw status
- If not active, do the following:
-
sudo ufw disable
-
sudo ufw enable
-
- Then the ufw status should show changes
-
sudo ufw status
-
-
Client Side: Install Remote Desktop Connection for Windows, MAC or Linux
For the client side (the local computer accessing the VM remotely), you can use remote desktop connection for Windows, MAC and Linux. The process is very similar in all three cases.
Simply download the app, open it and write the IPv4 address of the VM. You then will need to write the username and password to enter into your VM.
Download the App
- Client side Remote app
- Windows
- MAC
- Download in app store
- Linux
Connect Remotely
- General process
- In the Remote app, enter the following:
- the IPv4 Address of the VM
- the VM root-access username and password
- You now have remote desktop connection to your VM
- In the Remote app, enter the following:
Conclusion
You now have a remote access to the desktop environment of your VM. If you have any questions, let us know by writing a post on the Threefold Forum.