Guacamole: Testing an Azure Bastion alternative
Azure Bastion is a great product and I have been using it for a while now. It is easy to deploy and manage. During a recent discussion with a Cloud Architect “Guacamole” was mentioned to me as an alternative to Bastion. I thought of trying it in Azure. Before I could find the steps and requirements for its deployment in an IAAS instance I figured out an appliance was already available in Azure Marketplace. See the following screen
data:image/s3,"s3://crabby-images/c15e0/c15e02a3fdec805ef9f139166a244e120c7ba970" alt=""
To my surprise I found that this was completely free and I just needed to pay for the compute instance
data:image/s3,"s3://crabby-images/b3a0c/b3a0c2ce374500977b5ef7c645fdf9d8667a8849" alt=""
I choose a low spec virtual machine instance for my testing. I deployed it with Standard_B2s
data:image/s3,"s3://crabby-images/12d40/12d40731485c0bd066d0248d053d1c2327ca3a91" alt=""
I deployed it in an existing Virtual Network where I had another Windows VM. Deployment was quick and easy.
Note: Remember to allow NSG inbound rules to communicate on port 3389 from Private IP address of the Guacamole VM to the Windows VM you want to connect to.
I enabled boot diagnostics because the boot diagnostics showed the credentials to be used with the web interface. The credentials can be changed after you login to the console.
data:image/s3,"s3://crabby-images/8be41/8be416a77c2ea2dca4ea57e42d681ac3a9c1816d" alt=""
Note the credentials from the serial console, you can jump to the Guacamole web interface using the public IP address of the Guacamole VM.
data:image/s3,"s3://crabby-images/78507/78507cdaf4ccf69373627cece41a38b5ebbf8857" alt=""
Use the credentials to login to the web interface. Since it is a fresh installation of the Guacamole service there are no VM connections that exist. You can change password, Guacamole settings and setup new connections from the settings
data:image/s3,"s3://crabby-images/4672d/4672db4ebfce3007ac3fe18680c38f1314c49aa5" alt=""
Click “New Connection”
data:image/s3,"s3://crabby-images/c2ef2/c2ef2cd6dbc190a574a0dccd084492fbf7fcd35c" alt=""
Enter the settings as shown in the screenshot below. You need to provide a name for the connection, credentials to be used for authenticating to the VM. Most importantly choose “NLA (Network Level Authentication) and “Ignore Server Certificate”
data:image/s3,"s3://crabby-images/820c5/820c5d58ed9afe25a055c888992c107d1c57b236" alt=""
Save the connection settings and you should be able to see a new connection appear under connection. You need to go to the Guacamole console home
data:image/s3,"s3://crabby-images/8f267/8f26781c5026f8ffced9d001ebf0d48f88b8b90b" alt=""
From Home screen double click the connection to open an RDP session directly within the Guacamole console
data:image/s3,"s3://crabby-images/57eff/57eff78c9ba188bb860e6a36bd9d96d69b1c2ea8" alt=""
The below screenshot is from my Guacamole console.
data:image/s3,"s3://crabby-images/622a8/622a8d6089ea4e7e6cc9d9c9d45b72df3300d0f1" alt=""
Overall Assessment
- The RDP session/connection within the Guacamole console is pretty responsive and I didn’t see any lag. Setup was quick and easy. I didn’t run into any major issues.
- For a price of approximately AUD 50 and with the ability to shutdown all VM’s I think it is a good low cost alternative to Azure Bastion in a small test/lab setup.
- I do not think it is a replacement for Azure Bastion in a production environment since Bastion provides fully managed, highly available and scalable setup along with trusted security.
- Setting up and managing Guacamole would require much more effort than Bastion with both manual or automated deployments.
- Support has always been important factor and a priority and I it is needless to mention Azure Bastion would win.
I think it was a good 30 minute exercise to tickle the brain cells. Hope you liked this blog post. Feel free to send your feedback, comments and suggestions to gsjutla@lessergeek.com