In this article, I will describe how to create a Traffic Manager profile that delivers high availability for our web application.
In these steps, we will read about two instances of a web application. Both Instances are running in a different Azure region. We will create a Traffic Manager profile based on endpoint priority. The profile instructs user traffic to the primary site running the web application. Traffic Manager continuously monitors the web application. If the primary site is unavailable, it provides automatic failover to the (secondary site) backup site.
Sign in to the Azure Portal
Prerequisites
We need two instances of a web application deployed in two different Azure regions (1st in East US and 2nd in West Europe). Each one will serve as primary & failover endpoints for Traffic Manager.
Create a 1st Web App
1- In the Azure Portal screen, select + Create a resource.
data:image/s3,"s3://crabby-images/9a85a/9a85a04e029df652c649212d9516d95ee3510c7d" alt="microsoft azure portal"
2- Select Web under developer tools.
data:image/s3,"s3://crabby-images/1fd1f/1fd1fe935c7951a9cb9b8416208c6ad882f81ed6" alt="azure create a resource"
3- Click on Web App.
data:image/s3,"s3://crabby-images/99319/99319d535255e2290a2bb5bcf192668579ad56ec" alt="azure create a resource web app"
4- Create a Web App wizard, Basics tab.
Select your Subscription
Resource Group, select Create new
Enter a name (myrg-tm) and then click ok.
data:image/s3,"s3://crabby-images/344a7/344a768d9ccaaa7de6dbf091a45eb0b4b6c1e86a" alt="azure create web app basic"
5- Instance Details
Name – Type webappeastus.
Publish – Select Code.
Runtime stack – Select ASP.NET V4.7
Operating System – Select Windows.
Region – Select East US
data:image/s3,"s3://crabby-images/37658/37658de029688838a3e616d8d10bc09b3e102f4f" alt="azure web app instance details"
6- App Service Plan – Windows Plan (East US)
Select Create new
Type a name (AppServicePlanEastUS) and then click OK.
data:image/s3,"s3://crabby-images/198ea/198eafb5858b6d241aebbbd2680ee1845be3d2a4" alt="azure app service plan"
7- SKU and size – Select Standard S1.
Select Next : Monitoring >
data:image/s3,"s3://crabby-images/5c6a4/5c6a4d725ebd2b630a43299b72fe59e6ff4630a8" alt="azure app service plan sku"
8- Monitoring Tab
Application Insights
Enable Application Insights select No and then select Review + create
data:image/s3,"s3://crabby-images/8bd6e/8bd6e4ac02e0380a8d0fb608fd7e09879fce85a1" alt="azure create web app monitoring"
9- Review the settings, and then click on Create.
It will create a default web site when the Web App successfully deploys.
data:image/s3,"s3://crabby-images/a1a52/a1a525d268fd588e7d74e03397679a429cfdd38a" alt="azure create web app review"
Create a 2nd Web App
Settings | Value |
Resource Group | myrg-tm2 |
Web App Name | webappweurope |
Publish | code |
Runtime Stack | ASP.NET v4.7 |
Operating system | windows |
Region | West europe |
App service plan | Create new |
Name | AppServicePlanWEurope |
SKU and size | Standard S1 |
Next : Monitoring > | |
Enable Application insights | No |
Review + create | |
Create |
Now you can see two Web App successfully created.
data:image/s3,"s3://crabby-images/28fe4/28fe476bafb385fbdebb9bf71364bbb838f674ec" alt="azure app service directory"
Create a Traffic Manager profile
A Traffic Manager Profile that instructs user traffic based on endpoint priority.
1- Type traffic manager profile in Azure search bar then elect Traffic Manager Profiles.
data:image/s3,"s3://crabby-images/08215/08215d43d592e12a1994b531d173a82cda319481" alt="microsoft azure search bar"
2- Select the + Add button.
data:image/s3,"s3://crabby-images/3f606/3f6062fe5d8bdfdda25f6fe7c6956e983d2a75a9" alt="azure traffic manager profile"
3- Create Traffic Manager Profiles wizard
Type a name – myTManager
Routing Method – select Priority
Resource group – select myrg-tm and then click create.
data:image/s3,"s3://crabby-images/be8e8/be8e8bef58f87596201489981b3009962f34e821" alt="create traffic manager profile"
4- Traffic Manager profile successfully created.
data:image/s3,"s3://crabby-images/43fa0/43fa08757ab78a42c341f092372935fc1cc3e19e" alt="azure traffic manager profile directory"
How to Add Traffic Manager Endpoints
Add the website in the target resource (East US) as Primary Endpoint to route all the user traffic. Add the website in target resource “West Europe” as a Failover Endpoint. When the primary endpoint is unavailable, then the traffic automatically routes to the failover endpoint.
1- Select the Traffic Manager profile name that you created in the preceding section.
data:image/s3,"s3://crabby-images/626e7/626e773ecca320222a8007b140f730d87febf130" alt="azure traffic manager profile"
In the Traffic Manager profile
2- Select Endpoints under the Settings section and then click on + Add.
data:image/s3,"s3://crabby-images/d4947/d49472ff3def715ffe15132ae617b1d4d907c548" alt="azure traffic manager profile endpoint"
3- Type > Select Azure endpoint
Name > Type PrimaryEndpoint
Target resource type > Select App Service
Target resource > select webappeatus (East US)
Priority > Select 1
Select OK.
data:image/s3,"s3://crabby-images/632a0/632a0cb115bb4dfae040f20837c2a9e6825e591f" alt="azure traffic manager add endpoint"
Create a failover endpoint for your 2nd Azure region.
1- Click on + Add button again.
data:image/s3,"s3://crabby-images/6ace0/6ace0e48975de9bc4ba8916e01a7d23f8382ccf5" alt="azure traffic manager profile endpoint"
2- Type > Select Azure endpoint
Name > Type FailoverEndpoint
Target resource type > Select App Service
Target resource > select webappweurope (West Europe)
Priority > Select 2
Select OK.
data:image/s3,"s3://crabby-images/fc45c/fc45c0dcec4bbc85e57f56e1885d50f0ba3863b5" alt="azure traffic manager add endpoint"
3- When you are done adding the both endpoints, they are displayed in Traffic Manager profile. Notice that their monitoring status is Online now.
data:image/s3,"s3://crabby-images/5a507/5a5076cdfcc1df03d911fbb531a8b763c39d7553" alt="azure traffic manager profile endpoint"
Test Traffic Manager Profile
In this section, we will check the domain name of our Traffic Manager profile. You will also configure the primary endpoint to be unavailable. Finally, we get to see that the web app is still available. It is because Traffic Manager sends the traffic to the failover endpoint.
Check the DNS name
1- Go to your Traffic Manager profile name that you created in the preceding section.
Select the traffic manager profile and then an overview.
In the Traffic Manager profile, you can see the DNS name of your newly created Traffic Manager profile.
data:image/s3,"s3://crabby-images/94744/9474417f0f1696012d21d039342007479752a01f" alt="azure traffic manager profile overview"
View Traffic Manager in action
2- In the web browser, paste the DNS name of your Traffic Manager profile to view your Web App’s default website.
Note
In this scenario, all requests route to the primary endpoint because we set it to Priority 1.
data:image/s3,"s3://crabby-images/8a174/8a17471ac434e35e6b22c5009009f9069c27b580" alt="internet explorer azure app service"
3- Disable your primary site, to test Traffic Manager Failover:
In the Traffic Manager Profile page, select Endpoint under settings and then select PrimaryEndpoint.
data:image/s3,"s3://crabby-images/93e3e/93e3e5ef473101b5823dea7fc0a57ac4ca68ea76" alt="azure traffic manager profile endpoint"
4- In PrimaryEndpoint, select Disabled and then click on Save.
Close the PrimaryEndpoint window.
data:image/s3,"s3://crabby-images/718f9/718f969637c269ea42103be17b7bfb18b37e2a80" alt="azure traffic manager endpoint"
5- Notice that the status is Disabled now.
data:image/s3,"s3://crabby-images/77ac5/77ac57063bb6f446926247d6a938e24e30c0a7eb" alt="azure traffic manager endpoint"
6- Copy the DNS name of the Traffic Manager Profile from the preceding step to view the website in a new web browser session.
data:image/s3,"s3://crabby-images/18121/1812181d3873fef7d185c32153f5affbb908f071" alt="azure traffic manager profile overview"
7- Verify that the web app is still available.
The primary endpoint is not available, so you were routed to the failover endpoint.
data:image/s3,"s3://crabby-images/f2b14/f2b14d1b5a1f35af538ed60a316fc5a56e912e88" alt="internet explorer azure app service"