Developer Support

App Dev Manager Vijetha Marinagammanavar spotlights secure access to Azure VMs using Bastion.

In this blog post, I am going to introduce you to Azure Bastion and show how to create your first Azure Bastion host.

Azure Bastion is a new fully platform-managed PaaS service. It provides secure and seamless RDP/SSH connectivity to your virtual machines directly in the Azure portal over SSL. When you connect via Azure Bastion, your virtual machines do not need a public IP address.

Customers connecting to VM’s on private networks face security risks all the time. Exposing network assets to the public internet through Remote Desktop Protocol and Secure Shell increases the security perimeter, making it harder to manage and protect them. Azure Bastion is provisioned directly in a customer’s Virtual Network and supports all VMs in their VNet using SSL, without any exposure through public IP addresses.

Azure Bastion service is generally available now. This blog will provide a quick introduction of the service and steps to enroll the service in the environment to reach Azure VMs (Windows) over a secure way.

The availability of Azure Bastion is updated on Microsoft documentation. Please refer to for region availability and pricing.

Azure Bastion architecture from MS docsAzure Bastion architecture

Key features

  1. RDP and SSH directly in the portal
  2. Remote session over SSL for SSH/RDP
  3. No public IP needed on the Azure VM
  4. No need for an Agent inside the Azure VM
  5. Browser support for Edge and Google Chrome

Create an Azure Bastion Resource

  1. There are two ways to deploy an Azure Bastion Host over the Portal or via the Azure VM Blade.
  2. Login to your Azure portal and click “Create a new resource”.
  3. Then search for Bastion. Click Create to start the deployment wizard.
  4. Now choose a resource group to host the bastion resource, give it a name and pick a region (east-us for the demo). The Azure Bastion is deployed in a VNET, there is one-to-one relation between your VNETs, and your Azure bastion resources.
  5. We are using newly created VNET “vnet-demo” that is hosted for demo purpose. Please note that the wizard prompts to create a subnet in that VNET with an exact name of AzureBastionSubnet and with an IP prefix of at least /27.
  6. Create Subnet per requirements
  7. Go back to the Azure Bastion deployment wizard and select the vnet and newly created subnet.
  8. Azure bastion host requires creating a public IP address that will be used for SSL connectivity only from the internet. Now this IP is not going to be attached to your VMs in anyway. Azure automatically assigns a public IP to the service and generates a name that corresponds to the VNET declaration.
  9. Tagging: Don´t forget to assign tags for the service and all other resources, this helps you to get a well-defined Azure infrastructure.
  10. Click “Review + create “. The service will be provisioned in your VNET.
  11. Connect to a virtual machine: Select they virtual machine inside “vnet-demo” VNET.
  12. Click “Connect” and you will see 3 options – RDP, SSH and Bastion. Select “Bastion”.
  13. Enter the VM user credentials to connect to the VM and hit “Connect


Azure Bastion is a fully managed service by Microsoft and Microsoft hardens the service by default, but hardening to secure the Bastion host we should harden the subnet and use an NSG.

Create an NSG and define the following rules to the NSG,

  • Allow 443 from service tag Internet
  • Allow any traffic from a service tag called AzureCloud
  • Allow any traffic from a service tag called Gateway manager.


You can learn more about Azure Bastion by referring to below mentioned Microsoft Documentation


Discussion is closed.

Feedback usabilla icon