When you need to convert files into another file type you very often end up with “free”, “advertised” and potentially not secure Web Sites or tools to install locally. Today I will introduce you a solution that is under your control and secure. We will deploy HRConvert2 by zelon88 in Azure and look into options to create an SSL Certificate and secure an Azure hosted Public IP.
Table of Contents
Installation Options
You can use this installation guide for an Azure VM based solution, but also feel free to look into installing it locally on Linux or in a Docker container.
Azure Preperation – Network and Security
To be able to share the solution to others we want to seperate the solution, so I will create a seperate Azure Resource Group and Azure vNet with an Azure Firewall in place. The plan is to also utilize Letsencrypt for a HTTPS connection and look into options to even further improve security by using Azure services for internet facing solutions.
Azure Resource Group
Create the Azure Resource Group to use and follow your Azure Naming Convention.
data:image/s3,"s3://crabby-images/2c4cc/2c4cc1d4daf63310698c06755221cbe30b015f2e" alt="1. Create a Resource Group in GWC"
data:image/s3,"s3://crabby-images/51985/51985315e21430c5b0002d35ca2ffa329854d1ed" alt="2. Create a Resource Group in Azure Last Step"
Azure Virtual Network – Bastion – Firewall – Azure DDoS Protection
We will create a Virtual Network with a Subnet 10.1.1.0/24 for this service including Azure Bastion Services, so we can restrict the Access to the Network and try to keep things following fundamentals of a Zero Trust Approach for this web service.
For a full guide on creating Virtual Networks I do recommend the guide provided by Microsoft and make sure you complete the Azure Virtual Network Training Modules.
Since I have Azure credits to spent we will enable full functionality in this environment to be able to demo Azure Bastion, Azure Firewall and Azure DDoS Network Protection services. All of these come with a price and you should check the Azure Calculator for the costs, before deploying these.
data:image/s3,"s3://crabby-images/ffb6e/ffb6e126cd8337bd3bae06a53a8cc6fa1390dd11" alt="3. Create Virtual Network"
data:image/s3,"s3://crabby-images/abaa4/abaa450582659e5e13c4f4e0698c7e1d344b5209" alt="4. Create Azure Bastion"
data:image/s3,"s3://crabby-images/e69d1/e69d1997e9921c024a370b0ab0e355a8527d7400" alt="5. Create Azure Firewall"
data:image/s3,"s3://crabby-images/d60e3/d60e355633989991b6052bcb4320845e34b1c862" alt="6. Create Azure Firewall Policy"
data:image/s3,"s3://crabby-images/47ca6/47ca677e8b42e750133695486f47765a237723a4" alt="7. Create Azure DDoS Network Protection"
data:image/s3,"s3://crabby-images/fb80c/fb80ca61d548572fcd76124fbfcc6985aa1fd62a" alt="8. Create Azure DDoS Network Protection Name"
data:image/s3,"s3://crabby-images/4c3ad/4c3ad6c1e3af0a80f2d33731c4ba563a9afeca4c" alt="9. IP Addresses"
data:image/s3,"s3://crabby-images/40bed/40bedce7580c3769d451a7625c8d44efe550a100" alt="10. Review and Create"
If you are encountering issues with overlapping IP Subnets for the Azure Bastion and Azure Firewall the easiest way is to delete all subnets but the default one. Change the Subnet mask to /26 and than add back the other subnets by clicking on the “red highlighted messages” – see screenshot below.
data:image/s3,"s3://crabby-images/a7500/a75009ae188ab56229417041b4ee3b8992d5129d" alt="11. Message Required Subnets"
This deployment does require the deployment of several services. Be patient and grab a coffee to let the steps complete, before moving forward. If you like this guide, please follow me on LinkedIn or Bluesky.
data:image/s3,"s3://crabby-images/3cd58/3cd588ff527733b1b5f387cbbeb1ea0939126edc" alt="12. Azure Deployment"
To configure the advanced network services please check the individual guides below.
- Configure Azure Bastion
- Configure Azure Firewall Basic Protection
- Configure Azure DDoS Network Protection
Azure Preperation – Azure VM
Deploying Azure services through the Azure Marketplace is the most basic approach to install an Azure Service. In this guide we will use this approach to highlight an important settings to minimize costs and simplify the complexity by reducing the available services.
Important: Always hightlight “Azure Services only” to use the Microsoft services and not a 3rd party option, that could cause higher costs or have different support options and SLAs.
data:image/s3,"s3://crabby-images/dff54/dff541c62d8f6b7669febf936d1e2206267626bb" alt="13. Azure Services only"
For the Azure Virtual Machine Creation we will use the following settings:
- Resource Group: GWC-RG-hrconvert2
- Virtual Machine Name: GWC-Linux-HRConvert2
- Image: Ubuntu Server 24.04 LTS x64 Gen2
- VM Architecture: x64
- Select inbound ports: 443
- OS disk size: P10 (128 GB) – we want to convert files, so additional disk space is required
Utilize more details with the excercise from the Microsoft training module “Introduction to Azure virtual machines“.
data:image/s3,"s3://crabby-images/ef178/ef17867fc392f95dcb8787a4080005b11b65c08f" alt="14. Choose Resource Group and click Create"
data:image/s3,"s3://crabby-images/d2404/d2404f6b5b52a2f839de70f38a1377a6c8a98463" alt="15. Create VM from Azure Marketplace"
data:image/s3,"s3://crabby-images/ed273/ed273c8425232cf218e269a9d6f4184e0e266437" alt="16. Create the VM 2"
data:image/s3,"s3://crabby-images/59095/590954635eac22ebeb85f691f1ec6c69b0bd736a" alt="17. Create a Virtual Machine Basic1"
data:image/s3,"s3://crabby-images/55a62/55a62919c10bd8fbd4eb92ff637e645f017d4d84" alt="18. Create a Virtual Machine Basic1.png"
data:image/s3,"s3://crabby-images/078aa/078aa563dc2ad9a26ddd3ce46581a261ec198794" alt="19. Create a virtual machine disks"
data:image/s3,"s3://crabby-images/fe020/fe02096c977d61048d61890f28353a6aed94812a" alt="20. Create a virtual machine networking"
data:image/s3,"s3://crabby-images/6875a/6875a9df87e368dc5825546b5da2e44873f59fa3" alt="21. Create a virtual machine management"
data:image/s3,"s3://crabby-images/b19bd/b19bd134d169d8a3a5a1a933b2a31e7a491c5c39" alt="22. Create a virtual machine monitoring"
data:image/s3,"s3://crabby-images/b42ac/b42ac3fedb458db522752cc1c2f029f390dd0490" alt="23. Create a virtual machine advanced"
This will deploy your Azure VM that we will configure in the next steps of this guide. Please make sure you save the credentials and password files used for the deployment.
If you encounter issues with the connectivity to your Azure VM, please check the Azure Firewall and use these tools from my Blog “Windows Server 2025 – Monitoring TCP/IP” to check connections to HTTPS Port 443 and most importantly SSH Port 22.