Banyan Solution - Apache Guacamole - Setup Guide

  • Updated on Apr 25, 2022

In this setup guide, we’ll set up the Guacamole Proxy and MySQL using Docker containers.

1. Deploy MySQL

First, create a Docker volume where your MySQL server will store all your guacamole data:

$ docker volume create mysql-volume

Then, can run the mysql server, filling in ROOT_PASSWORD with whatever password you’d like:

$ docker run --name=mysql-guac -p 3306:3306 -v mysql-volume:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=ROOT_PASSWORD -d mysql/mysql-server:8.0.20

With this running, you’ll be able to access the mysql instance on port 3306, however MySQL will not allow you access from outside the docker container. To fix this, you can create a guacadmin user in the mysql database like so:

$ docker exec -it mysql-guac bash
$ mysql -u root -p
Enter password: ROOT_PASSWORD
...

mysql> CREATE USER 'guacadmin'@'%' IDENTIFIED BY 'ROOT_PASSWORD';
Query OK, 1 row affected (0.02 sec)

mysql> GRANT ALL PRIVILEGES ON *.* TO 'guacadmin'@'%' WITH GRANT OPTION;
Query OK, 0 rows affected (0.00 sec)

The above will log you into mysql as the guacadmin user and allow clients from outside the docker container to access the database.

2. Deploy Guacamole Proxy

Apache Guacamole is split into two main components, the proxy component (named gaucd), and the web application component. We’ll begin by deploying guacd, which acts as the proxy that allows users to use services like RDP and VNC from within their browser.

Deploying guacd using docker is as simple as starting the container:

$ docker run --name guac-guacd -d guacamole/guacd

You can check to make sure your mysql and guacd containers are running:

$ docker ps
CONTAINER ID   IMAGE                       COMMAND                  CREATED          STATUS                    PORTS                               NAMES
ac89c62d21b8   mysql/mysql-server:8.0.20   "/entrypoint.sh mysq…"   45 seconds ago   Up 43 seconds (healthy)   0.0.0.0:3306->3306/tcp, 33060/tcp   mysql-guac
01be978ac679   guacamole/guacd             "/bin/sh -c '/usr/lo…"   2 minutes ago    Up 2 minutes              4822/tcp                            guac-guacd

3. Instantiate MySQL Database

With guacd and mysql running, we now need to instantiate the MySQL database and prepare it for use with Guacamole. Thankfully this is very straightforward thanks to the built-in database initializer that’s shipped with Guacamole.

We’ve provided a sample script to use for this - save it as initdb.sql to be used from the MySQL Client.

Now we can connect to our MySQL database using the mysql client, and initialize the database using initdb.sql.

$ mysql -h 127.0.0.1 -P 3306 mysql  -u guacadmin -p
Enter password:
...

mysql> source initdb.sql

Your Guacamole deployment is ready to go!