In this guide, we are going to learn how to install Apache Guacamole on Ubuntu 21.04. Apache Guacamole is a clientless HTML5 web based remote desktop gateway which provides remote access to servers and desktops through a web browser. It supports standard protocols like VNC, RDP, and SSH.
Install Guacamole on Ubuntu 21.04
Guacamole is made up of two parts;
guacamole-server
, which provides the guacd proxy and all the native, server-side components required by Guacamole to connect to remote desktops.guacamole-client
which provides the client to be served by the servlet container which is usuallyTomcat
.
You need to install both of these components to setup Apache Guacamole web-based remote desktop client.
Install Guacamole Server on Ubuntu 21.04
Run system Update
Ensure your system package cache is up-to-date;
apt update
Install Required Build Tools
To install guacamole-server, you need to build it from the source. This, therefore, requires that you need install the required build tools before you can start to build guacamole-server component;
apt install -y build-essential libcairo2-dev libjpeg-turbo8-dev libpng-dev \
libtool-bin libossp-uuid-dev libavcodec-dev libavformat-dev libavutil-dev libswscale-dev \
freerdp2-dev libpango1.0-dev libssh2-1-dev libvncserver-dev libtelnet-dev \
libssl-dev libvorbis-dev libwebp-dev
A comprehensive description of these dependency tools is available on required dependencies section.
Building Guacamole Server on Ubuntu 21.04
To build guacamole-server, download the latest source archive tarball from Guacamole releases page. Apache Guacamole 1.3.0 is the latest release version as of this writing.
You can simply run the command below to download Apache Guacamole 1.3.0.
wget https://downloads.apache.org/guacamole/1.3.0/source/guacamole-server-1.3.0.tar.gz
Once the download is done, extract the source tarball.
tar xzf guacamole-server-1.3.0.tar.gz
Navigate to guacamole server source code directory;
cd guacamole-server-1.3.0
Run the configure
script to check if any required dependency is missing and to adapt Guacamole server to your system.
./configure --with-init-dir=/etc/init.d
For more configure options, run, ./configure --help
.
...
------------------------------------------------
guacamole-server version 1.3.0
------------------------------------------------
Library status:
freerdp2 ............ yes
pango ............... yes
libavcodec .......... yes
libavformat.......... yes
libavutil ........... yes
libssh2 ............. yes
libssl .............. yes
libswscale .......... yes
libtelnet ........... yes
libVNCServer ........ yes
libvorbis ........... yes
libpulse ............ no
libwebsockets ....... no
libwebp ............. yes
wsock32 ............. no
Protocol support:
Kubernetes .... no
RDP ........... yes
SSH ........... yes
Telnet ........ yes
VNC ........... yes
Services / tools:
guacd ...... yes
guacenc .... yes
guaclog .... yes
FreeRDP plugins: /usr/lib/x86_64-linux-gnu/freerdp2
Init scripts: /etc/init.d
Systemd units: no
Type "make" to compile guacamole-server.
Pay attention to out of the configure
script.
Compile and install Guacamole Server on Ubuntu 21.04;
make
make install
Next, run the ldconfig
command to create the necessary links and cache to the most recent shared libraries found in the guacamole server directory.
ldconfig
Running Guacamole-Server on Ubuntu 21.04
Reload systemd configuration files and start and enable guacd (Guacamole Daemon) to run on boot after the installation.
systemctl daemon-reload
systemctl start guacd
systemctl enable guacd
To check the status;
systemctl status guacd
● guacd.service - LSB: Guacamole proxy daemon
Loaded: loaded (/etc/init.d/guacd; generated)
Active: active (running) since Sat 2021-03-27 05:12:24 UTC; 1s ago
Docs: man:systemd-sysv-generator(8)
Process: 22887 ExecStart=/etc/init.d/guacd start (code=exited, status=0/SUCCESS)
Tasks: 1 (limit: 1042)
Memory: 9.9M
CGroup: /system.slice/guacd.service
└─22891 /usr/local/sbin/guacd -p /var/run/guacd.pid
Mar 27 05:12:24 hirsute systemd[1]: Starting LSB: Guacamole proxy daemon...
Mar 27 05:12:24 hirsute guacd[22888]: Guacamole proxy daemon (guacd) version 1.3.0 started
Mar 27 05:12:24 hirsute guacd[22887]: Starting guacd:
Mar 27 05:12:24 hirsute guacd[22888]: guacd[22888]: INFO: Guacamole proxy daemon (guacd) version 1.3.0 started
Mar 27 05:12:24 hirsute guacd[22887]: SUCCESS
Mar 27 05:12:24 hirsute guacd[22891]: Listening on host 127.0.0.1, port 4822
Mar 27 05:12:24 hirsute systemd[1]: Started LSB: Guacamole proxy daemon.
Install Tomcat Servlet
Apache Tomcat is used to serve guacamole client content to users that connects to guacamole server via the web browser. To install Tomcat, run the command below;
apt install tomcat9 tomcat9-admin tomcat9-common tomcat9-user -y
Tomcat9 is started and enabled to run on system boot upon installation. Check the status by running the command below;
systemctl status tomcat9.service
● tomcat9.service - Apache Tomcat 9 Web Application Server
Loaded: loaded (/lib/systemd/system/tomcat9.service; enabled; vendor preset: enabled)
Active: active (running) since Sat 2021-03-27 05:17:40 UTC; 2min 40s ago
Docs: https://tomcat.apache.org/tomcat-9.0-doc/index.html
Process: 24611 ExecStartPre=/usr/libexec/tomcat9/tomcat-update-policy.sh (code=exited, status=0/SUCCESS)
Main PID: 24615 (java)
Tasks: 29 (limit: 1042)
Memory: 72.8M
CGroup: /system.slice/tomcat9.service
└─24615 /usr/lib/jvm/default-java/bin/java -Djava.util.logging.config.file=/var/lib/tomcat9/conf/logging.properties -Djava.util.logging.manager=org.apache.jul>
Mar 27 05:17:45 hirsute tomcat9[24615]: Deployment of deployment descriptor [/etc/tomcat9/Catalina/localhost/host-manager.xml] has finished in [1,800] ms
Mar 27 05:17:45 hirsute tomcat9[24615]: Deploying deployment descriptor [/etc/tomcat9/Catalina/localhost/manager.xml]
Apache Tomcat listens on port 8080/tcp by default;
ss -altnp | grep 80
LISTEN 0 100 *:8080 *:* users:(("java",pid=24615,fd=37))
To allow external access to the serverlet, open the serverlet port 8080/tcp on UFW.
ufw allow 8080/tcp
Installing Guacamole Client on Ubuntu 21.04
guacamole-client contains provides web application that will serve the HTML5 Guacamole client to users that connect to your server. The web application will then connect to guacd on behalf of connected users in order to serve them any remote desktop they are authorized to access.
Create Guacamole configuration directory;
mkdir /etc/guacamole
Download Guacamole-client Binary
Guacamole client can be installed from source code or from ready binary. Binary installation is used in this demo.
Download Guacamole-client from Guacamole releases page for the respective latest version (v1.3.0 as of this writing) and store it in the configuration directory created above.
To download the current release version, v1.3.0 as of this writing, simply run the command below;
wget https://downloads.apache.org/guacamole/1.3.0/binary/guacamole-1.3.0.war -O /etc/guacamole/guacamole.war
Create a symbolic link of the guacamole client to Tomcat webapps directory as shown below;
ln -s /etc/guacamole/guacamole.war /var/lib/tomcat9/webapps/
Restart Tomcat to deploy the new web application;
systemctl restart tomcat9
Restart guacd daemon as well;
systemctl restart guacd
Configure Apache Guacamole on Ubuntu 21.04
Guacamole has two major configuration files;
/etc/guacamole
which is referenced by theGUACAMOLE_HOME
environment variable/etc/guacamole/guacamole.properties
which is the main configuration file used by Guacamole and its extensions.
There are also guacamole extensions and libraries configurations. You need to create the directories for these configs;
mkdir /etc/guacamole/{extensions,lib}
Set the guacamole home directory environment variable and add it to /etc/default/tomcat9
configuration file.
echo "GUACAMOLE_HOME=/etc/guacamole" >> /etc/default/tomcat9
Configure Guacamole Server Connections
To define how Guacamole connects to guacd
, create the guacamole.properties
file under /etc/guacamole
directory with the following content.
vim /etc/guacamole/guacamole.properties
guacd-hostname: localhost
guacd-port: 4822
user-mapping: /etc/guacamole/user-mapping.xml
auth-provider: net.sourceforge.guacamole.net.basic.BasicFileAuthenticationProvider
After that, save and exit the configuration file.
Next, link the Guacamole configurations directory to Tomcat servlet directory as shown below.
ln -s /etc/guacamole /usr/share/tomcat9/.guacamole
Configure Guacamole Authentication Method
Guacamole’s default authentication method reads all users and connections from a single file called user-mapping.xml
.
In this file,you need to define the users allowed to access Guacamole web UI, the servers to connect to and the method of connection.
Other authentication methods are supported, but beyond the scope of this tutorial.
To begin with, generate the MD5 hash of passwords for the user to be used for logging into Guacamole web user interface. Replace you password accordingly;
echo -n password | openssl md5
Output;
(stdin)= 5f4dcc3b5aa765d61d8327deb882cf99
or
printf '%s' password | md5sum
Output;
5f4dcc3b5aa765d61d8327deb882cf99 -
Be sure to replace password with your strong password.
Next, create the default user authentication file, user-mapping.xml
with the following contents.
vim /etc/guacamole/user-mapping.xml
<user-mapping>
<!-- Per-user authentication and config information -->
<!-- A user using md5 to hash the password
guacadmin user and its md5 hashed password below is used to
login to Guacamole Web UI-->
<authorize
username="guacadmin"
password="5f4dcc3b5aa765d61d8327deb882cf99"
encoding="md5">
<!-- First authorized Remote connection -->
<connection name="Ubuntu 20.04 Server SSH">
<protocol>ssh</protocol>
<param name="hostname">192.168.57.3</param>
<param name="port">22</param>
</connection>
<!-- Second authorized remote connection -->
<connection name="Windows 7 RDP">
<protocol>rdp</protocol>
<param name="hostname">192.168.56.103</param>
<param name="port">3389</param>
<param name="username">koromicha</param>
<param name="ignore-cert">true</param>
</connection>
</authorize>
</user-mapping>
If you dont specify the username and password in the file, you will be prompted to provide them while attempting to login, which i consider it abit secure.
If you need to explicitly define usernames and passwords in the configuration file, add the parameters;
<param name="username">USERNAME</param>
<param name="password">PASSWORD</param>
Save and exit the configuration file.
Restart both Tomcat and guacd to effect the changes.
systemctl restart tomcat9 guacd
Be sure to check the syslog, /var/log/syslog
or /var/log/tomcat9/CATALINA-*
for any issues.
Accessing Apache Guacamole from Browse
Apache Guacamole server is now setup. You can access it from web browser using the address http://server-IP:8080/guacamole
.
Use the credentials for the user whom you generated an MD5 hash for its password above.
Upon successful login, you get to Apache Guacamole web dashboard and you should be able to see the added connections.
Click on a connection to name to initiate remote login.
For example, to ssh into my Ubuntu server, just click on the connection name. This will get you a login prompt;
To login to Windows 7 via RDP, just click on Windows 7;
And there you go. Enter your password and proceed to your desktop.
You can now add more connections to your Guacamole.
Related guides;
Configure Guacamole SSL/TLS with Nginx Reverse Proxy
How to Enable RDP/SSH File Transfer Over Guacamole
Further Reading
Other tutorials
Install NoMachine Remote Desktop Tool on Kali Linux 2020