In this guide, I will show you how to create a Standard Load Balancer that load balances VMs across availability zones. Azure Load balancing provides a higher level of availability by distributing incoming requests across multiple VMs. This helps to defend your apps & data from a doubtful failure or loss of an entire datacenter. One or several availability zones, with zone-redundancy, may fail, & the data route remains as long as one zone in the region remains healthy.
Azure Standard Load Balancer just supports a “Standard Public IP address”. When we create a new public IP during creating the load balancer, it is automatically configured as a “Standard SKU” version, & is also automatically zone-redundant.
Steps to Create a Standard Load Balancer
Create a Standard Load Balancer
Create a Virtual Network
Create network security groups
Create VMs across multiple zones (zone redundant) and attach to the load balancer
Create load balancer backend pool
Create a load balancer health probe
Create load balancer traffic rules
Create a basic IIS site
Test load balancer
For more information about using Availability zones visit Microsoft Standard Load Balancer and Availability Zones.
Sign in to Azure Portal
Create Load Balancer
1- Choose Azure menu tab and then select Load Balancers.
data:image/s3,"s3://crabby-images/c21c8/c21c840f8833868d74890899acf3520054a66e1c" alt="microsoft azure menu"
2- Select the + Add button to create load balancer.
data:image/s3,"s3://crabby-images/329a5/329a53f7b8f6e9e051e7b073497d406010337a5e" alt="azure create load balancer"
3- Create load balancer wizard, Basics tab, select your resource group, or click new to create a new one.
data:image/s3,"s3://crabby-images/5a78c/5a78cdb8fe21824e66781f53366b2344fcf8479f" alt="azure create load balancer"
4- Type a resource group name and then click ok.
data:image/s3,"s3://crabby-images/e47b8/e47b829b3a3ad8c0be43d03535b50feded4be4a0" alt="azure create load balancer"
5- Type a name of your Load Balancer (myloadbalancer)
Region (Central US)
Type (Public)
SKU (Standard)
data:image/s3,"s3://crabby-images/c5c20/c5c201a088d71322cb6994a24d28c04c687d07f4" alt="azure create load balancer"
6- Public IP address name (mypublicip)
Availability zone (Zone-redundant)
Select Review + create >
data:image/s3,"s3://crabby-images/62876/62876e51a4bf31c5615aa29e4e90c039b36be7f2" alt="azure create load balancer"
7- Click on Create.
data:image/s3,"s3://crabby-images/57cb5/57cb504b75cb37d749be27f3f87da2a487fdbbb8" alt="azure create load balancer validation"
8- Now you can see load balancer successfully created.
data:image/s3,"s3://crabby-images/39b7f/39b7f45447a369b3512b940b682d107a048c703f" alt="azure create load balancer"
Create backend servers
In this step, I will create a virtual network, VM (virtual machines) in different zones. For the region, and then install IIS on the VMs to help test the zone-redundant load balancer. Therefore, if a zone fails, the health probe for virtual machines in the same zone fails, and then traffic continues to be served by VMs in the other zones.
Create virtual networks
Log in to the Azure portal
1- In the Azure portal, choose Azure menu bar and then select Virtual Network.
data:image/s3,"s3://crabby-images/75158/75158ac520517ed0f2c7d041f84eecd044f323c2" alt="azure menu"
2- Click on + Add to create virtual network.
data:image/s3,"s3://crabby-images/e5b08/e5b085d5ea38cddf08fabaad5feffec18f117bce" alt="azure create virtual network"
3- Select your subscriptions
Resource group (my-rg)
Instance details
Virtual network name (myvnet)
Regions (Central US) and then click Next : IP Address >
data:image/s3,"s3://crabby-images/468b8/468b83ccc579072f54cc06e92413cf4dfd2fc386" alt="azure create virtual network"
4- IP Addresses tab, type 10.0.0.0/16 for the IPv4 Address Space field. Click the + Add subnet button below.
data:image/s3,"s3://crabby-images/fc84c/fc84cd22050352c995231ee832308fed42c7d5d4" alt="azure create virtual network ip address"
5- Add subnet wizard;
Name (backendsubnet)
Subnet address range types 10.0.0.0/24 and then click Add.
data:image/s3,"s3://crabby-images/a2ee7/a2ee7ae9bdcb57605a0ac14a1e7b89bd983c4b76" alt="azure vnet add subnet"
6- Select Review + Create.
data:image/s3,"s3://crabby-images/14c85/14c8561a2178c74aea7299269f1c87dee386d139" alt="azure create virtual network ip address"
7- Select Create.
data:image/s3,"s3://crabby-images/8e6d5/8e6d5f5b6f9005cadd5256d1eb4894dabd3fd66c" alt="azure create virtual network validation"
8- Virtual network successfully created.
data:image/s3,"s3://crabby-images/a0242/a02429583a6cbeae24860de87a53ef09579e6e71" alt="azure create network virtual"
Create a network security group
Create “network security group” to specify inbound connections to our virtual network.
1- In Microsoft Azure portal, in the search box type Network Security Group, and select it.
data:image/s3,"s3://crabby-images/756b0/756b0671d159eec2556f61cb9c6ce0a070ddea12" alt="microsoft azure search bar"
2- Click Create network security group.
data:image/s3,"s3://crabby-images/674e5/674e57604891d82e0f09cc922ce2f1ac9e35b092" alt="azure create network security group"
3- Create network security group wizard
Name of the existing resource group (my-rg)
Name (mynsg) Network Security Group
Region (Central US) and select Review + create
data:image/s3,"s3://crabby-images/92711/9271157961e977a9a23114128bda701b3bf4f6f7" alt="create network security group"
4- Select create.
data:image/s3,"s3://crabby-images/14a87/14a87f77e5acb777b96b4126d7e0422e6eb3d078" alt="create network security group validation"
5- Network Security group successfully created.
data:image/s3,"s3://crabby-images/0e0ea/0e0ea1eb79db68a3323d4f2e1113eb13ec79da17" alt="azure network security group"
Create network security group rules
In this portion, we will create network security group rules to allow inbound connections using HTTP and RDP using the Azure portal.
1- Select your network security group.
data:image/s3,"s3://crabby-images/2dd6a/2dd6abfa01d3e9df2f3f45b79e43bf313c6a8a13" alt="azure network security group"
2- Under Settings, select Inbound security rules, and then click Add.
data:image/s3,"s3://crabby-images/ec3b2/ec3b2882bbc180c73ccfd5bf064007455972d669" alt="azure inbound security rules"
3- Source (Service Tag)
Source service tag (Internet)
Destination port ranges (80)
Protocol (TCP)
Action Allow (Allow)
Priority (100)
Load balancer rule name (allowhttp)
Description (allow HTTP traffic)
Click Add.
data:image/s3,"s3://crabby-images/f82da/f82da6faca10f6361cd06b4286ea8336c813e95a" alt="azure add inbound security rules"
4- Create another rule to allow for an inbound RDP connection using port 3389.
data:image/s3,"s3://crabby-images/73dd6/73dd658d74b0727599dfd306d439b1ce8e207354" alt="azure add inbound security rules"
5- Source (Service Tag)
Source service tag (Internet)
Destination port ranges (3389)
Protocol (TCP)
Action Allow (Allow)
Priority (200)
Load balancer rule name (allowrdp)
Description (allow RDP connection)
Click Add.
data:image/s3,"s3://crabby-images/cd749/cd749b1727562059e3bc65db427b8e61eaafc12e" alt="azure add inbound security rules"
6- Inbound security rules successfully created.
data:image/s3,"s3://crabby-images/d8c92/d8c929f02fd98e14616904d2167606a2b58b3e1a" alt="azure inbound security rules"
Create virtual machines
Now we need to create virtual machines in different zones (zone 1, zone 2, and zone 3) for the region that can act as “backend servers” to the load balancer.
First VM
1- Select Azure menu bar and then select virtual machine.
data:image/s3,"s3://crabby-images/dd47d/dd47d7ff73f021148592b4dda1f77387428b13b3" alt="microsoft azure menu"
2- Select + Add
data:image/s3,"s3://crabby-images/0ea07/0ea07e7d8f9a6146f103f2e8e0854bba52e42454" alt="azure virtual machine"
3- Select existing resource group (my-rg).
data:image/s3,"s3://crabby-images/7b801/7b801f56bcefefc014f5a9bdb73758b6a15944ed" alt="azure new vm wizard"
4- Virtual machine name (myvm1)
Region (Central US)
Availability options (Availability zone)
Availability zone (1)
Image (Windows Server 2019 Datacenter
data:image/s3,"s3://crabby-images/6892d/6892d6e361b7ebca6ec5e7573663e15bc07910d4" alt="azure vm instance details"
5- Enter username, password
Public inbound ports (Allow selected ports)
Select inbound ports (HTTP, HTTPS, RDP)
Select Next : Disks > and then select Next : Networking >
data:image/s3,"s3://crabby-images/4b13b/4b13b1174d3f5e74db19cad227abab1f8bcb762a" alt="azure new vm wizard"
6- Virtual network (myvnet)
NIC network security group (advanced)
Configure network security group (mynsg)
Select Next : Management >
data:image/s3,"s3://crabby-images/85331/85331f6ba819b98b7adb73fed5d8acf6ec0fc925" alt="azure new vm networking"
7- Boot diagnostic (Off) select Review + create and then select review + create.
data:image/s3,"s3://crabby-images/9a180/9a18026d9a5679e00f710904050affadc260b381" alt="azure new vm management"
Create 2nd VM
Settings | Value |
Resource group | my-rg |
Name | myvm2 |
Region | Central US |
Availability set | Availability zone |
Availability zone | 2 |
Server | Windows server 2019 datacenter |
Administrator account | Username, password |
Public Inbound ports | HTTP, HTTPS, RDP |
Networking, virtual network | myvnet |
NIC network security group | Advanced |
Configure network security group | mynsg |
Management | Boot diagnostic off |
create |
Create 3rd VM
Settings | Value |
Resource group | my-rg |
Name | myvm3 |
Region | Central US |
Availability set | Availability zone |
Availability zone | 3 |
Server | Windows server 2019 datacenter |
Administrator account | Username, password |
Public Inbound ports | HTTP, HTTPS, RDP |
Networking, virtual network | myvnet |
NIC network security group | Advanced |
Configure network security group | mynsg |
Management | Boot diagnostic off |
create |
Now you can see three virtual machines have been created.
data:image/s3,"s3://crabby-images/0f523/0f523caf32c1f7783b73dc060a567710688fa49a" alt="azure virtual machine"
Install IIS on VMs
How to install Webserver IIS
1- # install IIS server role
Install-WindowsFeature -name Web-Server -IncludeManagementTools
2- # remove default htm file
remove-item C:inetpubwwwrootiisstart.htm
3- # Add a new html file that displays server name
Add-Content -Path “C:inetpubwwwrootiisstart.htm” -Value $(“Hello World from” + $env:computername)
4- C:inetpubwwwroot
Right-click on iisstart and open with notepad
data:image/s3,"s3://crabby-images/7a570/7a57085b87629721c3221695c46a96c2eed16f0b" alt="windows explorer wwwroot"
5- Rename text.
data:image/s3,"s3://crabby-images/6d00d/6d00d821474898f5e5cd2ff6da1e164bfdb598fe" alt="notepad"
Repeat steps 1 to 5 to install web server IIS and the updated iisstart.htm file on myVM2 and myVM3.
Create load balancer Resources
In this section, we will configure load balancer settings for a backend address pool and a health probe, and specify load balancer and NAT rules.
Create a backend address pool
To “distribute traffic” to the VMs virtual, a “backend address pool” contains the IP addresses of the virtual (NICs) connected to the load balancer.
1- Select Azure menu and then select load balancer.
data:image/s3,"s3://crabby-images/2a6d5/2a6d54d823b183b1f4995e1942e79426d596af8a" alt="microsoft azure menu"
2- Click on myLoadBalancer.
data:image/s3,"s3://crabby-images/774a3/774a3195b9aa056916b33513261fe70f9e9a4dae" alt="azure create load balancer"
3- Under Settings, select Backend pools, then click + Add.
data:image/s3,"s3://crabby-images/f7325/f73255c0ef23fbd847771f875317c82370993457" alt="azure load balancer backend pool"
4- Add a backend pool wizard, do the following.
backend pool name (backendpool).
Virtual network, in the drop-down menu, select (myvnet)
Under Virtual machines click the add button.
data:image/s3,"s3://crabby-images/cdd0f/cdd0f521bbfecb5898e3a31161f269ee9990f9b1" alt="azure add vm to backend pool"
5- Select the virtual machines to add to backend pool and then click add.
data:image/s3,"s3://crabby-images/de65c/de65c0af9af42511de028dc403afc4fde8d49a62" alt="azure add vm to backend pool"
6- Click Add.
data:image/s3,"s3://crabby-images/51238/512386abe9e9e723c21fa3eb700815596b1c74ce" alt="azure add backend pool"
7- Make sure your load balancer backend pool setting displays all the 3 VMs and then select Health probe.
data:image/s3,"s3://crabby-images/6e955/6e95521b3c30e8c0cc19b72d81cae47f0458e850" alt="Microsoft azure backend pools"
Create a health probe
To permit the load balancer to monitor the status of our app, you use a health probe. The health probe dynamically adds or removes virtual machines from the load balancer rotation based on their response to health checks.
1- Click + Add.
data:image/s3,"s3://crabby-images/21c66/21c66c870401d82cf258b3039865ddea6169d321" alt="azure health probe"
2- Add health probe wizard
Name (healthporbe)
Protocol type (HTTP)
Port number (80)
Number of Interval (5 seconds)
Number of “Unhealthy threshold” or consecutive probe failures (two seconds) that must occur before a VM is considered unhealthy.
Click OK.
data:image/s3,"s3://crabby-images/35382/35382fc986fb6b4dc8fca0a0475277cdd64b5069" alt="azure add health probe"
3- Health probe successfully created
Under settings, click on the load balancing rule
data:image/s3,"s3://crabby-images/69b24/69b24089a571f3156b7d8402fccb24560021a5b3" alt="azure load balancer health probe"
Create a load balancer rule
A load balancer rule is used to specify traffic how it distributed to the VMs. You specify the front-end IP configuration for the incoming traffic and then the back-end IP pool to receive the traffic, ahead with the required source and destination port.
1- Click + Add.
data:image/s3,"s3://crabby-images/d857d/d857de7521062d71cb559cd5ad836d15390aff01" alt="azure load balancing rule"
2- Add load balancing rule wizard.
Name (lb-rule)
IP version (IPv4)
Protocol type TCP
Port number (80)
Backend port (80)
Backend pool (3 virtual machines)
Health probe name (healthprobe)
Click Add.
data:image/s3,"s3://crabby-images/f7d3f/f7d3f140335cab611e2bac99b5283a917a408594" alt="azure load balancing rule"
Test the load balancer
1- Select Azure menu and then select Load balancers.
data:image/s3,"s3://crabby-images/b63d0/b63d065baaedddfc8965895c7744150eaaa3b774" alt="microsoft azure menu"
2- Click on myloadbalancer
data:image/s3,"s3://crabby-images/90385/90385f0fd129dd3109d5fcbf3cf4873731c0245c" alt="azure load balancers"
3- On the overview screen, find the public IP address for the Load Balancer.
Select mypublicip
Copy the public IP address,
data:image/s3,"s3://crabby-images/605d7/605d7236c13d758f5bce1fe1030895e1b351cb12" alt="azure load balancer overview"
4- Open any web browser and then paste it into the address bar.
On the browser, the default page of IIS Web server is displayed.
data:image/s3,"s3://crabby-images/0dc51/0dc513a6078ce2e95214a5fab6812d017cd52b5b" alt="standard load balancer"
5- You can force-refresh your web browser, to see the load balancer distribute traffic across the VMs distributed across the zone
data:image/s3,"s3://crabby-images/a6cde/a6cdeb89e752f59a4901a8b12252871497a24b4e" alt="standard load balancer"
Read more: Internal Load Balancer in Microsoft Azure.