In this article, I will explain, how to Improve Website Response using Traffic Manager. Use Traffic Manager to create a highly responsive website by directing user traffic to the website with the lowest latency. Generally, the datacenter with the minimum latency is the one that is closest to the geographic distance.
In this article, you learn how to:
Create two virtual network
Create 2 VMs running a basic website on (IIS)
Configure DNS name for the VMs (running IIS)
Create two tests VMs to view Traffic Manager in action
Create a “Traffic Manager profile” for improved website performance
Add VM (Instance) endpoints to the Traffic Manager profile
View Traffic Manager in action
Prerequisites
In the interest of see the Traffic Manager in action, this article requires that you deploy the following:
2 instances (VMs) of basic websites running in different Azure regions – (East US and West Europe).
2 test VMs for testing the Traffic Manager – 1st VM in West Europe and the 2nd VM in East US. The test VM (Instance) is used to represent how Traffic Manager Routes user traffic to the website that is running in the same region as it provides the lowest latency.
Improve Website Response using Traffic Manager
Sign in to the Microsoft Azure portal
Create a virtual network
1- In the search bar type (virtual networks) to find or from the Azure portal menu and then select virtual networks.
data:image/s3,"s3://crabby-images/5cd41/5cd413e99d9da0b18400e87be2ff7a6d8d483507" alt="azure menu"
2- In the virtual network, select the add button create a virtual network.
data:image/s3,"s3://crabby-images/439a3/439a38090b27d8d6f1910c35d9dc21274bcffcd2" alt="azure create virtual network"
3- Create virtual network window, choose your subscription. Resource Group, select create new to create.
Enter a resource group name (rg-vnet) and then click ok.
data:image/s3,"s3://crabby-images/70960/709600737abd5eb5d6acdd169ecd064149d3c22f" alt="azure create virtual network"
4- Under the instant details type a virtual network name (vnet01).
Choose a location to use as the basis for your virtual network. Select a location that is near to your location to increase performance. Click on Next: IP Addresses >
data:image/s3,"s3://crabby-images/91756/917569080447e31720faea91c4efa57fe6ffeb1f" alt="azure create virtual network basic"
5- Choose an address space IPv4 address space, I am selecting 10.1.0.0/8, but if you prefer to use a different address feels free. Click + Add subnet
data:image/s3,"s3://crabby-images/ed070/ed07038c5b6a2d085dae4c5b7e81faf5dc7bb8e5" alt="azure create virtual network ip address"
6- In the Add subnet wizard, type a subnet name (vnet-subnet) and then type 10.1.0.0/24 for Subnet address range.
To create service endpoint policy to allow traffic then select a service under services.
data:image/s3,"s3://crabby-images/3f3ad/3f3ad479b0fbbaadfcddb36b062d089422aaf32d" alt="azure vnet add subnet"
7- Click Next : Review + Create >
data:image/s3,"s3://crabby-images/ac448/ac4480d058d70567520e21e578b2554bb9f23c5d" alt="azure create virtual network ip address"
8- Virtual network validation passed, selects Create.
data:image/s3,"s3://crabby-images/de6e3/de6e3e89b81d311f9dd87034a32d7a9b968b0fac" alt="azure create virtual network validation"
9- To create a 2nd virtual network follow the above steps from 3 to 6 again with the following changes.
Setting | Value |
Resources Group | rg-westus |
Name | vnet-westus |
Region | (US) west US |
IPv4 address space | 192.168.0.0/16 |
Subnet name | subnetwestus |
Subnet address range | 192.168.1.0/24 |
Create |
9- Virtual network overview.
data:image/s3,"s3://crabby-images/d61f6/d61f6e8781086b6d4227f676852f46e079410eed" alt="azure create network virtual"
Create Virtual Machines
Now we need to create VM in each virtual network so that we can communicate between them.
1st VM
1- Azure portal menu tab, select Virtual Machines.
data:image/s3,"s3://crabby-images/138d8/138d8e0a485f37a3a024a9531fbd430edb6313b5" alt="microsoft azure menu"
2- Select the + Add button to create virtual machine.
data:image/s3,"s3://crabby-images/f1ee3/f1ee3749c92c61962dede14068ada8510f4fb028" alt="azure virtual machine"
3- Resource group select existing (rg-eastus).
data:image/s3,"s3://crabby-images/c0af6/c0af6370b307d8b1a950c9ad4e2e9d05138f2911" alt="azure new vm wizard"
4- Instance details
Enter a virtual machine name (server-eastus)
Region select (East US)
Image selects Windows Server 2019 Datacenter. You can select a different operating system, but the remaining steps presume you selected Windows Server 2019 Datacenter.
data:image/s3,"s3://crabby-images/9a98f/9a98f9abcbc91f8c896b536a47905581e47ad4e7" alt="azure vm instance details"
5- Administrator account.
Enter a username (jamil), Password.
Public inbound ports choose allow selected ports.
Select inbound ports (HTTP, RDP) and then click Next : create >
data:image/s3,"s3://crabby-images/6f0cc/6f0cc8de71cddc0a7589498df40309e1acda62fc" alt="azure new vm wizard"
6- Under Management tab
Monitoring boot diagnostics (off) and then click Review + create
data:image/s3,"s3://crabby-images/fda2d/fda2d3271f04147cf24beeda38621c8da45e7625" alt="azure new vm management"
7- Select create
data:image/s3,"s3://crabby-images/ba65e/ba65e39d5dae62cadaeebc51e02dea996c67c804" alt="azure new vm create"
Create the second VM
Complete steps 2 to 7 again with the following changes:-
Name | Value |
Resource group | rg-westus |
Virtual machine name | server-westus |
Region | (US) West US |
Image | Windows Server 2019 Datacenter |
Administrator account | username password |
Public inbound port | allow selected ports |
Select inbound ports | HTTP, RDP |
Management tab | monitoring boot diagnostic (off) |
Review + create | |
Create |
The VMs take a few minutes to create. Now the both VMs (web1, web2) successfully created.
data:image/s3,"s3://crabby-images/b8ef5/b8ef5d3d983909b6b03a7dfc62e4f6eea2dcbbbe" alt="azure virtual machine"
Configure DNS names for the VMs running IIS
In this section, we will configure the DNS names for the IIS servers – server-eastus and server-westus.
1- Select server-eastus
data:image/s3,"s3://crabby-images/54937/54937330fd1b11cfd4de3fc4ac1ac830dc3f98c2" alt="azure virtual machine"
2- Overview page, under DNS name, select Configure.
data:image/s3,"s3://crabby-images/0fc00/0fc000b416c79b3315e8e0f3b5a3b7f857053f55" alt="azure virtual machine overview"
3- Select Configuration under settings, under DNS name label (optional), enter a unique name, and then select Save.
data:image/s3,"s3://crabby-images/8abf1/8abf1b88926f33908b3e949057e99cf59a86c2f0" alt="azure virtual machine configuration"
4- Select server-westus.
data:image/s3,"s3://crabby-images/5f06f/5f06fe93e982cd816cc65905e609385552210410" alt="azure virtual machine"
5- On the overview page, under DNS name, select Configure.
data:image/s3,"s3://crabby-images/db499/db499e346f06e0c4bba344d80fb1488db96f3d42" alt="azure virtual machine overview"
6- Configuration page, under the DNS name label (optional), type a unique name and then select Save.
data:image/s3,"s3://crabby-images/5b63f/5b63f2ac794ea4d69ebb5fde1cc25060bc392f62" alt="azure virtual machine configuration"
Create Test VMs
In this section, you create a VM (vmtest-eastus and vmtest-westus) in each Azure region (East US and West US). We will use these VMs (Virtual Machines) to test how Traffic Manager routes traffic to the nearest IIS server when we browse to the website.
1- On the upper left corner of the Azure portal, select the Azure menu and then select the virtual machine.
data:image/s3,"s3://crabby-images/37e1a/37e1a6a048fc25e2f635f0143c59d53be3c4721f" alt="microsoft azure menu"
2- In Create a virtual machine, click on + add button.
data:image/s3,"s3://crabby-images/d5344/d534484f61a6ca68e30afee0ae660bb3758de013" alt="azure virtual machine"
3- In the Basics tab
Select Subscription
Resource Group – Select rg-eastus.
data:image/s3,"s3://crabby-images/2d32a/2d32a2af5497e525a6bc7bb385949cc12325aab6" alt="azure new vm wizard"
4- Instance Details
Virtual machine name – Type vmtest-eastus.
Region – Select East US.
Image – Windows Server 2019 Datacenter.
data:image/s3,"s3://crabby-images/4daaa/4daaa94257df97bc3e28aa8c3f3b70dc55e9d178" alt="azure vm instance details"
5- Administrator Account
Username – Enter a user name.
Password – Enter a password.
Public inbound ports – Choose Allow selected ports.
Select inbound ports – Choose HTTP, RDP in the pull down box.
data:image/s3,"s3://crabby-images/17a1e/17a1ec1939417994e8d47612544abc08c3953739" alt="azure new vm wizard"
6- Review the settings, and then click Create.
data:image/s3,"s3://crabby-images/9711a/9711a527cefcdfcea7c7e884f330ca2a72a1995f" alt="azure new vm create"
Follow the Steps to Create a 2nd VM.
Settings | Value |
Resource group | rg-westus |
Name | vmtest-westus |
Region | West US |
Server | Windows server 2019 datacenter |
Administrator account | Username, password |
Public Inbound ports | HTTP, RDP |
Review + create | |
create |
The VMs take a few minutes to create. Please do not continue with the remaining steps until all VMs are created.
data:image/s3,"s3://crabby-images/d7d13/d7d138548de43f40b97d890af07f57155d5f24f8" alt="azure virtual machine"
Create a Traffic Manager profile
To create a Traffic Manager profile that instructs user traffic by sending them to the endpoint with the lowest latency.
1- In the Azure search type traffic manager, select Traffic Manager Profiles.
data:image/s3,"s3://crabby-images/0b5f1/0b5f175c57b661df891cd29b804bdc8c695a599e" alt="azure search bar"
2- Traffic Manager profiles, click the + Add.
data:image/s3,"s3://crabby-images/3d67a/3d67a44ce22a7d99e7c1dda547f3322e29fb8768" alt="azure traffic manager profile"
3- In the Create Traffic Manager profile wizard
Name – Type a name (trafficmanager33)
Routing method – type Performance
Select Subscriptions
Resource group – select rg-eastus
Select Create
data:image/s3,"s3://crabby-images/6e79f/6e79f8c36ec73ba6a77ed41de01cc6658aac60f0" alt="azure create traffic manager profile"
4- Traffic Manager profiles.
data:image/s3,"s3://crabby-images/91462/91462569ff9b393c58ada3f89bc72eb800d9b260" alt="azure traffic manager profile"
Add Traffic Manager Endpoints
Add the two VMs running the IIS servers – server-eastus & server-eastus- to route user traffic to the endpoint closest to the user.
1- In the portal’s search bar, search for the Traffic Manager profile and then select it.
data:image/s3,"s3://crabby-images/de684/de68401d7127fef03e030cc0e429d65a9914d445" alt="azure search bar"
2- In Traffic Manager profile, click on trafficmanager33.
data:image/s3,"s3://crabby-images/879f8/879f88306291c519a3b059c9b39613bcd7be136f" alt="azure traffic manager profile"
3- Select Endpoints under settings, and then click + Add.
data:image/s3,"s3://crabby-images/a7ffe/a7ffe716934e4ef81ed76e249f51d58742a9c71b" alt="azure traffic manager endpoint"
4- Add Endpoint
Type – Azure endpoint
Name – eastusendpoint
Target Resource type – Public IP address
Public IP address – server-eastus-ip
Click Add
data:image/s3,"s3://crabby-images/22068/22068b08d5b6bb4fc4c00363d3b0eb99856c73ea" alt="azure add endpoint wizard"
5- Select + add button again for second endpoint.
data:image/s3,"s3://crabby-images/6f3ea/6f3eaf38dd3bb3250bf4856bed08c309b598473d" alt="azure traffic manager endpoint"
6- Add Endpoint
Type – Azure endpoint
Name – westusendpoint
Target Resource type – Public IP address
Public IP address – server-westus-ip
Click Add
data:image/s3,"s3://crabby-images/e10a4/e10a42e578ea53c9580bcaf283a25ddaafa2d015" alt="azure add endpoint wizard"
7- After the addition of both endpoints completed, they will displayed in Traffic Manager Profile together with their monitoring status as Online.
data:image/s3,"s3://crabby-images/346c9/346c9dd63e8192ed9afcc6a40dd4803078226424" alt="azure create endpoint wizard"
Test Traffic Manager Profile
Determine DNS name of Traffic Manager Profile
In this step, we use the DNS name of the Traffic Manager profile to visit the websites.
1- In the Azure search bar, search for the Traffic Manager profile name and then select it that we created in the preceding section. select the traffic manager profile.
data:image/s3,"s3://crabby-images/ad1cf/ad1cf3dbb1bf58923e8666d059af2b829dce6c0e" alt="azure traffic manager profile"
Overview
2- Your Traffic Manager profile will display the DNS name of your newly created one.
Copy DNS name
data:image/s3,"s3://crabby-images/e2eb2/e2eb285b6a48dd3f8ddf5b6afd531df5263b8801" alt="azure traffic manager profile overview"
Improve Website Response using Traffic Manager
3- Go to the virtual machines and then click vmtest-eastus.
data:image/s3,"s3://crabby-images/f600b/f600b55319c741356e85b2ee9da6c475d96fb82b" alt="azure create virtual machine"
4- Connect virtual machine (server-eastus), using RDP.
5- Open web browser on the VM (instance) vmtest-eastus, enter the DNS name of the Traffic Manager profile to view the website. Since the VM located in East US, you are routed to the nearest website hosted on the nearest IIS server server-eastus that is located in East US.
data:image/s3,"s3://crabby-images/88a71/88a71d505961ac7d24acef5dbc7d7f2548ed0f82" alt="east server"
6- Connect virtual machine (server-westus), using RDP
7- Open web browser on the VM vmtest-westus, type the DNS name of your Traffic Manager profile to view your website. Since the VM located in West US, you are routed to the nearest website hosted on the nearest IIS server server-eastus that is located in West US.
data:image/s3,"s3://crabby-images/3f80d/3f80dbcf557532e9a3b31fb57b9f6f2632d777e9" alt="west server"