IIS ARR Presentation
ARR is an add-in (plugin) that installs on IIS and allows to transform the Windows Web server into a Reverse Proxy.
ARR is a free add-on that installs on an IIS service and allows:
- HTTP (S) routing
- Load Balancing
- Offloading SSL
- CDN (cache)
Example of deployment with IIS / ARR:
data:image/s3,"s3://crabby-images/104fb/104fb4436afca8f46b254d546fd7d31eee45bf08" alt="IIS/ARR example of implementation"
Prerequisites
For the implementation of ARR you need:
- Web services to publish (IIS / Apache / nginx …)
- A server with IIS installed.
ARR installation
From the IIS console, launch Web Platform Installer.
In the search box enter ARR 1 and press Enter on the keypad.
data:image/s3,"s3://crabby-images/c37ea/c37eaf2a6b8ae5e523bbab09b65b0f00e84ba764" alt="Rechercher ARR"
Select Application Routing 3.0 Beta 1 and press the Add 2 button.
data:image/s3,"s3://crabby-images/5eef8/5eef8ff67b57c20e755463fa090147997dd99eb2" alt="Choisir ARR 3.0"
Click on the Install 1 button.
data:image/s3,"s3://crabby-images/88bfd/88bfd7c3a24ece633982ac376c82aca1b62587be" alt="Lancer l'installation"
Click on I accept 1 .
data:image/s3,"s3://crabby-images/4090c/4090c52063b41d8edf3be388bcdf31e7fb66064a" alt="Accepter la licence"
Wait during the installation.
data:image/s3,"s3://crabby-images/dc726/dc72668274a6215949fafa423a680175d195e8e2" alt="Patienter ..."
The 3 components required for the installation and operation of ARR are installed, click on Finish 1 to close the installation wizard.
data:image/s3,"s3://crabby-images/ef232/ef232a8c2d886a6f5534e6734b4ab89b33816104" alt="Le couple IIS ARR est installé"
Restart the IIS console, the ARR 1 administration components should be available.
data:image/s3,"s3://crabby-images/1dfec/1dfec9f809d76934f4a66617a9a9c9bbf97cc04a" alt="Composant ARR disponible"
Configuration: Simple Routing
In this part we will set up a simple routing of the HTTP protocol. The HTTP requests will arrive on the ARR server and it will transfer them to the WEB server hosting the site (s).
La première étape est de créé une Ferme de serveur qui correspond à un ou plusieurs serveurs Web qui héberge l’application et ensuite de modifier la règle de réécriture pour le routage vers la bonne ferme en fonction de l’url.
Select Server Farm 1 , right click on it and click Create Server Farm … 2 or go through the Actions menu.
data:image/s3,"s3://crabby-images/07118/071184f1ffb4a6a3c9f181a2906279ee37bc4ee0" alt="Création d'une ferme"
Enter the name of Server Farm 1 (by convention the access DNS name), check the box Online 2 if it is not done and click Next 3 .
data:image/s3,"s3://crabby-images/b2b7c/b2b7ce48301a0247f2c143495930b52acf9de7a2" alt="Entrer le nom de la ferme"
Enter the name or IP of the servers hosting site 1 and click on Add 2 .
data:image/s3,"s3://crabby-images/9df5a/9df5a5390fd0eee4f8591afb4efc7d6512cf1340" alt="Indiquer les serveurs web qui héberge l'application"
Once the server (s) added 1 click the button Finish 2 .
data:image/s3,"s3://crabby-images/19805/19805cdaf17210de07ea357f9007ffff916175ed" alt="Cliquer sur terminer pour créer la ferme"
Click Yes 1 to confirm the automatic creation of rewrite rule (routing).
data:image/s3,"s3://crabby-images/0b807/0b8079621ef95146214cc0f93d42c66bb9b87a08" alt="Création automatique des regles"
Automatic rules rely on the name of the farm to rewrite. We will see later how to modify the rules for reliability.
The first “server farm” 1 is created and available in the IIS administration interface.
data:image/s3,"s3://crabby-images/e1af0/e1af0edff923c74547e39cf404f0ce6725385f5c" alt="Aperçu de la ferme"
Expand the Server Farms 1 folder and select the farm that has just been created 2 . In the central area 3 there are the available actions.
data:image/s3,"s3://crabby-images/f07e1/f07e1a976b12fc8b9bf4c28a336f06bcfbae429b" alt="Actions sur possible sur une ferme"
We will now take a closer look at the rewrite rules.
Click on Routing Rules 1 .
data:image/s3,"s3://crabby-images/73c99/73c99acdb99947d73dc7e41b6bb1cc705c22cf41" alt="Ouvrir la parametrage du routage"
In the Actions menu click Url Rewrite … 1 .
data:image/s3,"s3://crabby-images/7582c/7582ccce9aca9c5a74a1b7ba387cf4dba7154431" alt="Ouvrir les regles"
We see the transfer rule automatically create 1 . Double click on it to display the details of the rule.
data:image/s3,"s3://crabby-images/0bbe2/0bbe2352a9d65751e9b9dca0c1fa100fd266bbc8" alt="Liste des regles"
In the case where a single web server hosts all the sites internets on vhosts (sites), it would be possible to make a single rule by keeping the header of the host.
A : we see here that the traffic arriving on the server is transferred and not rewritten as can be seen in the list of rules. We will now make sure to limit the transfer to the URL lab.rdr-it.intra. Click on Conditions 1 .
data:image/s3,"s3://crabby-images/25e26/25e26ee710ee7f000f9c0f50ad634577f7a36624" alt="Edition de la régle"
Click the Add button 1 . In the new window that opens, enter the server variable that will be tested here {HTTP_HOST} 2 , in the model field 0 3 enter the (sub) domain to be processed and click OK on 4 to save the condition.
data:image/s3,"s3://crabby-images/0f625/0f625cab10dda47aaef0398b45b1de82306fddf5" alt="Ajout de condition"
A : the condition is added, click on Apply 1 to take into account.
data:image/s3,"s3://crabby-images/32b11/32b110e0f3c847dfe73f61d7be263f08a2c2eef0" alt="Condition appliquée"
For tutorial purposes, I added a second arr-demo.rdr-it.intra site that goes through ARR and is hosted on the same IIS server.
The DNS records of type A sites must point to the ARR server.
data:image/s3,"s3://crabby-images/45d05/45d056ba77848e68b5c4af093682859d9cdc49dd" alt="Résolution de nom via ping"
Launch an internet browser and go to the sites.
data:image/s3,"s3://crabby-images/a5fc5/a5fc50d211130accdc5af2d64118f2f937398473" alt="Résultat navigateur"
To validate the passage in ARR, it is possible to check it at the level of the IIS logs which is in C: / inetpub / LogFiles / W3SVC1
(by default). The passage through ARR can also be monitored at the 1 monitoring level on the farm with a 2 statistics page.
data:image/s3,"s3://crabby-images/0d840/0d8404fd80a0f4f373b1d03c7e4b1b63e8c0a544" alt="IIS ARR : statistiques"
data:image/s3,"s3://crabby-images/eaa6e/eaa6e228918c307c5f0f12cdbbc74d4fbbb65625" alt="IIS ARR : statistiques"
Configuration : Offloading SSL
The purpose of the SSL offloading is to publish a site using ARR in HTTPS and to communicate the ARR server with the web server in HTTP. This solution allows the Web server to be unloaded from encryption.
Install the certificate on the ARR server
Since ARR is linked to only one site (Default Web Site) on IIS, if multiple domains need to be supported, it is necessary to have a SAN type certificate.
For the tutorial, I generated a self signed certificate in * .rdr-it.intra to cover all subdomains.
Go to the root of the IIS console 1 and then to Server certificates 2 .
data:image/s3,"s3://crabby-images/edbe7/edbe7641cde84e2958a29bc3741491ab44fb9981" alt="Gestion des certificats dans IIS"
Click Import 1 in the Actions menu. Select the certificate in pfx 2 format, enter the private key (password) 3 , choose the storage magazine 4 (Web Hosting) and click OK 5 .
data:image/s3,"s3://crabby-images/2cd61/2cd6108f7e36ba0ca8d49cf870c41d156514145a" alt="Importer le certificat"
The certificate is imported 1>.
data:image/s3,"s3://crabby-images/b57cc/b57cc40279b22986f0159a5c1ae6bda8b55b7961" alt="Certificat importé"
Display the list of sites available on the server by clicking on the folder Sites 1 , select the default site 2 , right click on it and click on Links … 3 .
data:image/s3,"s3://crabby-images/aa97c/aa97c92bb3535085c2e328ab14a0fc919bb521c0" alt="Gestion des liaisons"
Click the Add button 1 .
data:image/s3,"s3://crabby-images/ac9f6/ac9f663797e276e14e24870cb1db18ade3c7808e" alt="Ajout d'une nouvelle liaison"
Link type choose https 1 , select certificate 2 then press OK button 3 .
data:image/s3,"s3://crabby-images/b722e/b722e169103b8d3439415821473f14dddb0acc68" alt="Configuration liaison SSL"
The HTTPS link is added 1 . Exit by clicking Close 2 .
data:image/s3,"s3://crabby-images/db859/db8590b3e8323c1e11895b8a889d781b277a9fcb" alt="Liaison ajoutée"
Configuration of rewrite rules – routing
Go to the rewrite rules management page.
Add a new rule from the Action menu by clicking Add Rules 1 , choose Blank Rule 2 and click OK 3 .
data:image/s3,"s3://crabby-images/5521b/5521bbbde94d1a93aa8e2739f762c446963fe1fb" alt="Ajout d'une nouvelle regle"
Name the rule 1 , click Conditions 2 to expand the option, add the two rules 3 (the first verifies that the call is made in https and the second limit to the domain ). In the Action section, select the diagram 4 then the farm 5 and click Apply 6 .
data:image/s3,"s3://crabby-images/ef6b2/ef6b251b6270f22c5d3a42ed09797f959efb6272" alt="Parametrage de la regle"
Go back to the list of rules, it is added 1 .
data:image/s3,"s3://crabby-images/fc473/fc473ffaa02bf5d6b909839017d163611294fdc5" alt="Regle ajoutée"
Launch a browser and access the site in https.
data:image/s3,"s3://crabby-images/6ba43/6ba43621c000b0e39a7cd7d9dba5f921f6db083e" alt="Test HTTPS"
As can be seen below, there is no SSL link on the IIS A> site.
data:image/s3,"s3://crabby-images/7e9a3/7e9a37fbcaed90cb12a2d1159ea824ca5674bd33" alt="Liaison sur le serveur web cible"
To force access in HTTPS (SSL), it is necessary to add before the unload rule, a rule that makes a 301 HTTP to HTTPS redirect.
Configuration: Enabling the cache
One of the features available with ARR is cache system, which saves queries on web servers.
Sur le serveur créé un dossier pour stocker le cache.
From the IIS console, click Application Request Routing 1 .
data:image/s3,"s3://crabby-images/11b95/11b9526468f772171262e1357bec2678543243f1" alt="Console IIS ARR"
From the Actions menu click on Add Drive … 1 .
data:image/s3,"s3://crabby-images/1eaae/1eaae95e7904869ce92c98ba570ccf12efc19c1c" alt="Ajouter un emplacement"
Enter the path of the file 1 , define a limit 2 then click on OK 3 .
data:image/s3,"s3://crabby-images/f03bb/f03bb8a0e4c350f958cb201550f91bd7b9533361" alt="Paramétrage de l'emplacement"
Storage for the cache is declared 1.
data:image/s3,"s3://crabby-images/961ce/961ce1451c00f7f3f81f4bfd483d7a68fe903180" alt="Stockage déclare"
Go to one of the sites declared in the farm 1 and click on Caching 2 .
data:image/s3,"s3://crabby-images/24749/24749b12b0083b77a1bce968859d35f28608f1d5" alt="Paramétrage du cache sur la ferme"
If this is not the case, activate the cache by checking the box 1 Enable disk cache and click Apply 2 .
data:image/s3,"s3://crabby-images/b855e/b855e69eb6481163202da903689193f38cc4ffa5" alt="Activation du cache"
Refresh the site where the cache is enabled.
Open the folder where the cache is written, you should have A files.
data:image/s3,"s3://crabby-images/1eeb4/1eeb4b04e16f37f2d600a507a37260673e56c619" alt="Validation du bon fonctionnement"