The write-up would cover the deployment of a Standard Azure load balancer. A load balancer ensures traffic is evenly distributed across all the workers in the group during demands. A load balancer is a public-facing one typically and it accepts traffic from outside and forwards to internal servers which are typical with just private IPs. The deployment of a standard log balancer is similar to that of a basic load balancer deployment.
data:image/s3,"s3://crabby-images/3c338/3c338adae3c0a4b798b3f026e2b1521aa79fe958" alt=""
Terminologies in Load Balancer
data:image/s3,"s3://crabby-images/bef69/bef69be0b2c238ce57330d65b2fa4cb4a11c8f06" alt=""
Comparison between load balancers
The basic load balancer is free to use but there is no SLA and no high availability whilst the standard load balancer is charged by hourly usage and has HA built into it via the use of AZ.
Basic Load Balancer | Standard Load Balancer |
It’s free | Charged per hour |
No SLA | 99.99% SLA |
Health probes – HTTP, TCP. A simple TCP handshake is done | HTTP Health probes – HTTP, TCP, HTTPS In this, a request is even made to check if a path is available default.html Session Persistence is a feature on Standard ELB |
No perf metrics available | Perf metrics available |
No support for AZ | Support for AZ |
Machines in the backend pool need to be part of Avail set or scale set | Standalone VMs can be part of this load balancer as well, however, should be part of the same network |
1- Create two Virtual machines
data:image/s3,"s3://crabby-images/0c52a/0c52a0637531ab1a6b884d9f39a80640efbb2621" alt=""
2- Install IIS on both servers
Add-WindowsFeature Web-Server
Set-Content -Path “C:\inetpub\wwwroot\Default.html” -Value “This is the server $($env:computername) !”
3- Disoassociate Public IPs from VMs. We don’t need public IPs on our VMs as this will come from our Public IP on the load balancer.
data:image/s3,"s3://crabby-images/e5f46/e5f4631295b74eac67227bdb1babe45e66ae941f" alt=""
4- Create and attach a new NSG to the subnet
data:image/s3,"s3://crabby-images/ea19a/ea19af383f8420a4ad774fafa24d76c8f992d318" alt=""
5- If we need the load balancer to talk to the outside world we need the NSG rules in place
data:image/s3,"s3://crabby-images/ea58c/ea58c371c72788beb6bb461d2c35b381fcd2e92b" alt=""
6- Associate NSG to subnet
data:image/s3,"s3://crabby-images/af5b6/af5b661bf6908ecedae563023776c158746bc428" alt=""
7- Create a load balancer
data:image/s3,"s3://crabby-images/f24da/f24dacdee570e0ff39c406d9ece7c84fa5cbb8ad" alt=""
8- Give the load balancer a name and choose the Standard
data:image/s3,"s3://crabby-images/95181/951813b79161c99d152d213fba565f927cfb1021" alt=""
9- Under the front-end, IP configuration give it a name, create a public IP for our load balancer and ensure the IP Assignment is set to Static
data:image/s3,"s3://crabby-images/9c772/9c772097bbfb3801b70e5afddde7feea9ad69dea" alt=""
10 – Give the backend pool a name, and under associations choose virtual machine.
data:image/s3,"s3://crabby-images/cd82f/cd82fdf23bb4de02d4b54e61a87456df4a378428" alt=""
11- Both VM’s are added
data:image/s3,"s3://crabby-images/52456/52456c50b980d7354183c320c73ed7e7080baa7e" alt=""
12 – Skip all the inbound/outbound rules for now and click Create
data:image/s3,"s3://crabby-images/0c970/0c9709292e5e0bb15d938c78495ad97f234374df" alt=""
14- Our load balancer is now ready
data:image/s3,"s3://crabby-images/0081d/0081df4fd5879ec81599714e57bc32b8bd1b4995" alt=""
14- Our frontend IP configuration shows the public IP of our load balancer.
data:image/s3,"s3://crabby-images/1b6c2/1b6c26016a93f244bb962c995ee0aa22adfff04e" alt=""
15- Our backend pool config shows both our registered VM’s in the load balancer.
data:image/s3,"s3://crabby-images/141e4/141e4f9085b8b0418b6205909d6a36576fadc488" alt=""
16- Under the health probe add the below paremeters. If the load balancer does not get successful health back, after 2 consecutive attempts it will mark the VM as failed and move to spin new instances.
- Name of the rule: – Probe-A
- Protocol: – HTTP
- Port: – 80
- Path:- Default.html
data:image/s3,"s3://crabby-images/2c62e/2c62e2636352138ff95e952d1fa1b6560066cbf1" alt=""
17- Under the load balancing rule, they define the following
- Name of the rule: – ELB-Rule-A
- Front-end IP: – Choose the front-end web tier ip
- Back-end Pool: – Choose the backend pool we created
- Port:- this is the front-end port ( ie: Port 80 on our ELB)
- Back-end port – this is the backend port ( ie: IIS server )
- Health Probe: – add the health check parameter defined
- Session Persistence – This is a cookie setting that allows users to stick to a session.
data:image/s3,"s3://crabby-images/62cf5/62cf590dbe8bb06a208080fa44a6c654c8835ee8" alt=""
18- Our load balancing rule is defined
data:image/s3,"s3://crabby-images/43a40/43a404d2c03094eec32641b6c131677c08a1e9aa" alt=""
Standard Load Balancer NAT rules
NAT rules define how our load balancer communicates to the outside world. There are two NAT two rule to define
- Inbound NAT rule – Allows connections into the load balancer
- Outbound NAT rule- Allows connections out the load balancer eg: Internet
Defining Inbound NAT Rule
How do I connect to RDP now because we don’t have public IPs on our private servers?
We can do a bastion or there are some nat rules we can do on the load balancer so that we map the public IP of elb to the RDP port of the internal vm
19- Under the NAT rule we need the following for our first VM
- Name of the name rule – ELB_WEB_NAT_RULE_A
- Target machine – Choose our first VM in backend pool
- Choose front end ip as our load balancer
- Front end Port – add a random number
- Service tag – choose RDP protocol
- Backend port – add 49156 which is the RDP port of our backend VM.
So here, whatever the request comes onto port 49157 of our load balancer, it’s forwarded to the RDP port 3389
data:image/s3,"s3://crabby-images/27a4d/27a4de93640a00b58e7bc29d01b73cf95292a1d4" alt=""
20- Under the NAT rule we need the following for second VM
- Name of the name rule – ELB_WEB_NAT_RULE_B
- Target machine – Choose our second VM in the backend pool
- Choose front end ip as our load balancer
- Front end Port – add a random number
- Service tag – choose RDP protocol
- Backend port – add 49156 which is the RDP port of our backend VM.
data:image/s3,"s3://crabby-images/caeac/caeacd52c5b9ba563eb180e41e1e56a29e422c4a" alt=""
21- Both our Inbound NAT rules are defined.
data:image/s3,"s3://crabby-images/b5179/b5179c557fe259634cde9b0f6c6cbb1dff30489c" alt=""
22- Finally, review our load balancer settings
data:image/s3,"s3://crabby-images/f96f5/f96f58f87da3d02f10b71c9746c1f4f393e79f59" alt=""
23- Finally, review our load balancer output
data:image/s3,"s3://crabby-images/94adf/94adfb1173ba822c5fe51f45905c79a8fa33c7b6" alt=""
data:image/s3,"s3://crabby-images/86712/867125e99ef8b31b258f9ae13393e8739e9e5d37" alt=""
24- Testing our RDP Access
So this shows any traffic coming on our ELB on ports 49157 will be forwarded to 3389 in RDP
data:image/s3,"s3://crabby-images/d0094/d009450113bb00924045b164fdd71bf2a1d128b2" alt=""
25- Connect to VM via RDP browser
data:image/s3,"s3://crabby-images/8a4c1/8a4c1241b0304a1885f0c300c12aa6ca6962a3eb" alt=""
data:image/s3,"s3://crabby-images/4d0ab/4d0ab89d59645ab5b2382dbdecaca0bd49a62776" alt=""
Defining Outbound NAT Rule
26- Add all these paremeters required
- Name of the name rule – Outbound_RuleA
- Front-end IP address – select the web front-end IP
- Backend pool – choose web-pool
- Port Allocation- Use the default number of ports
data:image/s3,"s3://crabby-images/ce700/ce700bdd419442fb7ba1bc69cd33c157fbbb5ea6" alt=""
27- Our outbound rule is now ready
data:image/s3,"s3://crabby-images/3c55a/3c55a3c11c796f6b3b9012e17d42f058efdcc159" alt=""
28- We now have internet connectivity on these VM’s via our load balancer.
data:image/s3,"s3://crabby-images/4d999/4d9999fa37e62e4c119c4db974e4630d9f9b06a2" alt=""