Click here to Skip to main content
16,021,580 members
Articles / Web Development / IIS

Deploying ASP.NET Websites on IIS 7.0

Rate me:
Please Sign up or sign in to vote.
4.76/5 (146 votes)
4 Sep 2008CPOL9 min read 1.2M   303   82
This article describes some features and architecture of IIS 7.0 and deployment of ASP.NET sites on IIS
IIS7.JPG

Introduction

  1. Introduction to IIS 7.0
  2. Features of IIS 7.0
  3. Basic Architecture of IIS 7.0
  4. How to Deploy ASP.NET Websites on IIS 7.0
  5. How to Create Application Pool
  6. Assign Application Pool To Your Application
  7. Configure Web Garden on IIS 7.0
  8. IIS 6.0 Vs IIS 7.0
  9. Where Do I Get IIS 7.0
  10. References
  11. History

Introduction to IIS 7.0

Microsoft Internet Information Services (IIS) 7.0 in Windows Server 2008 and Windows Vista provides a secure, manageable platform for developing and administrating and hosting Web applications and services. It has been completely redesigned and Restructured .IIS 7.0 provides features and functionality for administrators to effectively manage Web infrastructures; developers to rapidly build Web applications and services; and hosters to Web hosting.

IIS7_new.JPG

Features of IIS 7.0

Following are some features of IIS 7.0:

  • IIS 7.0 provides features and functionality that enable administrators to reliably and effectively manage Web infrastructures.
  • IIS 7.0 has a distributed file-based configuration system that enables IIS settings to be stored in web.config files along with the ASP.NET settings.
  • IIS 7.0 provides a cost-effective, more scalable Web server platform for delivering reliable Web hosting to a broad set of customers.

Major innovations in IIS 7.0:

  • A modular, extensible core Web server
  • A unified, distributed file-based configuration system
  • Integrated health monitoring and diagnostics
  • A set of new administration tools with delegation support

For more features and product understanding, check here.

Basic Architecture of IIS 7.0

The following diagram shows the Overall Architecture of IIS 7.0 which contains HTTP.Sys, SvcHost.exe, Application Pool and Worker Process(W3Wp).

II7_Archi.JPG

The main components of IIS 7.0 are HTTP.Sys, Svchost.Exe, Application Pool , Worker Process (W3WP.exe) and Configuration Store.

HTTP.Sys: It the Kernel mode Protocol stack which listens to the HTTP and HTTPS Request. W3SVC and WAS are the parts of Svchost.exe. W3SVC is the Listener of Request from kernel mode that is passed by the HTTP.Sys. W3SVC also interacts with Windows Activation Process which is managed by the worker process by starting, stopping and recycling the application pool. It was also responsible for Health Monitor of Application Pool during runtime. Configuration stores all web.config and ASP.NET Settings and other configuration in XML Hierarchy form. W3wp.exe is a long-running process that processes requests and generates responses.

The following diagram shows you the process flow of IIS 7.0. This is the flow of User Request to IIS and gets the Response from IIS.

ProceessFlowofIIS.JPG

User Request Pass from Kernel Level to User Level Via Http.Sys and then passes to svchost, and then goes to Application Pool.

For more details, please click here.

How to Deploy ASP. Net Websites on IIS 7.0

From now onwards, I will describe one example to deploy your ASP.NET websites on IIS 7.0.

Step 1: From Visual Studio, publish your Web application.

Step 2: Copy the published application folder to "C:\intepub\wwwroot" [default] folder.

Step 3: From RUN - > inetmgr -> OK

The following screen will come. This is the main page for any application. There are three panels.

Main_DefaultIIS.JPG

"TestWeb" is a recently pasted webapplication on your wwwroot folder.

Step 4: We need to convert it to an application, just right click and then Click on "ConvertToApplication" as shown in the following picture:

ConvertToApplication.JPG

After converting it to application, its icon will be changed and then you can set the property for your web application from the middle pane. You can set IIS Authentication Mode, Default Page Just like IIS 6.0:

ConvertedToApplication.JPG

You can change Security Settings on Authentication Section. By default Setting will be set from your web.config itself. As in my web.config Form Authentication was set that's why, Forms Authentication has been Enabled. If we want to change the status, just double click and update status to Enabled to Disabled or Vice Versa.

AuthenticatinSettings.JPG

Now one most important part is to set the Application Pool for your application.

How to Create Application Pool

A site can contain many applications including that site’s default application, which is called the root application. In addition to belonging to a site, an application belongs to an application pool, which isolates the application from applications in other application pools on the server .

Step 1: Right Click on Application Pool and give the name of your pool. Here, I have given "pool" and select Framework and click on OK:

PoolCreation.JPG

Step 2: If you are writing some thing on the server [may be writes Error Events Logs], you need to change the Pool Identity to Local System. Right click on Pool Identity setting as shown in the following image:

There are three identities of Application Pool:

  • Network Service
  • Local Service
  • Local System
changePoolIdentity.JPG

Assign Application Pool To Your Application

Now, we need to assign the Application Pool to our web application.

Step 1: Right Click on "TestWeb" Application and Select "Advanced Settings":

asingAppPool.JPG

Step 2: Finally assign your created Application Pool "pool" to "TestWeb" Application.

FinalAppPoolAsign.JPG

Now you can run your application by just typing http:\\localhost\testweb and it can be accessible on network by IP also.

Configure Web Gardens in IIS 7.0

I have split this section into some parts. These are:

What is Application Pool ?

Application pools are used to separate set of IIS worker processes that share the same configuration. Application pools enable us to isolate our web application for better security, reliability, and availability. The worker process serves as the process boundary that separates each application pool so that when one worker process or application is having an issue, other applications or worker processes are not affected.

aPPpIOOL.JPG

Figure: Application Pool With Worker Process On IIS Server

In your IIS, there may be more on Web sites hosted and by creating Application Pool, you can just assign a Separate Worker Process to your application. I have already discussed how you can assign Application Pool to your web application.

Types of Application Pools

There are two predefined Application Pools is IIS 7.0:

  1. DefaultAppPool (Integrated)
  2. ClassicAppPool

None of the Application Pools are Installed by default when IIS 7.0 is installed. Classic Application Pool is installed when ASP.NET 2.0 is installed in the System.

Identity Of Application Pool

Application pool identity configuration is an important aspect of security in IIS 7.0, because it determines the identity of the worker process when the process is accessing resource. This Settings comes form IIS 6.0. in IIS 5.0. There the Application pool runs under the local system account. In IIS 7.0, there are three predefined Identities that are the same as IIS 6.0

Applicationpool Identity Description
LocalSystem LocalSystem is a built-in account that has administrative privileges on the server. It can access both local and remote resources
LocalServicesLocalServices built-in account has privileges of an authenticated local user account. It does not have any network access permission.
NetworkServicesThis is the default Identity of Application Pool. NetworkServices has privileges of authenticated local user account and it can have access remote resource as machine account.

How to Create An Application Pool and Assign It to a Web Application?

This has already been discussed.

Creating Application Pool and Assigning it to a Web Application

What is Web Garden?

By default each Application Pool runs with a Single Worker Process (W3Wp.exe). We can assign multiple Worker Processes With a Single Application Pool. An Application Poll with multiple Worker process is called "Web Gardens". Many worker processes with the same Application Pool can sometimes provide better throughput performance and application response time. And each worker process should have their own Thread and Own Memory space.

WEb_Garden.JPG

Fig: General Block Diagram of Web Garden.

As given in the picture, in IIS Server there may be multiple Applicationpool and each application pool has at least a single Worker Process. Web Garden should contain multiple Worker processes.

There are certain restrictions to use Web Garden with your web application. If we use Session Mode to "in proc", our application will not work correctly because session will be handled by different Worker Process. To avoid this type of problem, we should have to use Session Mode "out proc" and we can use "Session State Server" or "SQL-Server Session State".

Main Advantage: The worker processes in a Web garden shares the requests that arrive for that particular application pool. If a worker process fails, another worker process can continue to process requests.

How to Create Web Garden?

Create a New Application Pool. Right Click -> Advance Setting -> Go To Process Model Section, set the Value for Maximum Worker Process.

IIS_Update.JPG

Is It Recommended to use Web Garden?

It not always recommended to use Web Garden to your Application. It effects the performance of your sites except in very specific cases like some long running synchronous requests or application is very unstable.

IIS 6.0 Vs IIS 7.0

The main advantages of IIS 7.0 is Modular Design which gives some benefits to IIS 7.0 over IIS 6.0. The following table shows you some differences of IIS 6.0 and IIS 7.0.

Features

IIS 6.0

IIS 7.0

ArchitectureMonolithicModular
SetupMost Features InstalledMinimum installation based on role
Extended FeaturesISAPI Filter and ISAPI ExtensionAdded Module and handler in managed or native code
Customize UINormalCustomize for .NET

There are many more differences.

Where Do I Get IIS 7.0

IIS 7.0 will not be available with all Operating Systems. There are some specific OS and specific Versions for IIS 7.0.

Operating System With EditionAvailable
Windows Server 2008Yes
Windows Vista (Home Basic)No (Default) need to install
Windows Vista (Home Premium)No (Default) need to install
Windows Vista (Business)Yes
Windows Vista (Ultimate)Yes

Reference

History

  • 08/20/2008:
    • Article published
  • 08/28/2008:
    • Added Section: Web Garden on IIS 7.0
    • Modified some text

License

This article, along with any associated source code and files, is licensed under The Code Project Open License (CPOL)


Written By
Technical Lead
India India
.NET Consultant | Former Microsoft MVP - ASP.NET | CodeProject MVP, Mentor, Insiders| Technology Evangelist | Author | Speaker | Geek | Blogger | Husband

Blog : http://abhijitjana.net
Web Site : http://dailydotnettips.com
Twitter : @AbhijitJana
My Kinect Book : Kinect for Windows SDK Programming Guide

Comments and Discussions

 
QuestionHow-to Deploying programmatically using powershell Pin
kiquenet.com4-Dec-15 0:33
professionalkiquenet.com4-Dec-15 0:33 
QuestionIIS 7 Pin
Avantha Siriwardana10-Dec-14 19:02
Avantha Siriwardana10-Dec-14 19:02 
GeneralMy vote of 5 Pin
Aravindba22-May-14 1:21
professionalAravindba22-May-14 1:21 
QuestionHTTP Error 404.0 - Not Found Pin
Deepak Kr Meena6-Apr-14 20:05
Deepak Kr Meena6-Apr-14 20:05 
GeneralMy vote of 5 Pin
Joezer BH28-Jul-13 3:38
professionalJoezer BH28-Jul-13 3:38 
QuestionProblem Related Remote Connection On IIS Local Host Pin
Sourabhghosh20-Jun-13 22:04
Sourabhghosh20-Jun-13 22:04 
Questionjqueries and javascripts of my websetup are not working after creating websetup Pin
Kunalchatterjee12-Jun-13 11:16
Kunalchatterjee12-Jun-13 11:16 
QuestionDid not work for me this way... but worked other way . what is the difference Pin
nainakarri6-Jun-13 19:12
nainakarri6-Jun-13 19:12 
GeneralMy vote of 5 Pin
Itz.Irshad5-May-13 19:14
Itz.Irshad5-May-13 19:14 
GeneralMy vote of 1 Pin
R koyee20-Mar-13 21:24
R koyee20-Mar-13 21:24 
Questionits working Pin
Amitkala2-Mar-13 21:45
Amitkala2-Mar-13 21:45 
QuestionSqlserver database commands are not working Pin
Member 878084223-Feb-13 8:56
Member 878084223-Feb-13 8:56 
GeneralMy vote of 5 Pin
dpalash5-Feb-13 18:50
professionaldpalash5-Feb-13 18:50 
GeneralMy vote of 5 Pin
Maddy_10088-Jan-13 23:17
Maddy_10088-Jan-13 23:17 
QuestionCaution/ Recommendation Pin
Member 212708910-Dec-12 4:00
Member 212708910-Dec-12 4:00 
GeneralMy vote of 5 Pin
ANJYR29-Aug-12 5:25
ANJYR29-Aug-12 5:25 
QuestionIIS7 configuration error Pin
hariom_soni18-Aug-12 4:11
hariom_soni18-Aug-12 4:11 
AnswerRe: IIS7 configuration error Pin
shahnawaz92863-Feb-13 19:53
professionalshahnawaz92863-Feb-13 19:53 
QuestionNice Article Pin
Suvabrata Roy19-Jul-12 21:55
professionalSuvabrata Roy19-Jul-12 21:55 
GeneralSession Problem Pin
Member 927399818-Jul-12 10:33
Member 927399818-Jul-12 10:33 
GeneralNice Artical Thanks... Pin
Suvabrata Roy11-Jul-12 21:06
professionalSuvabrata Roy11-Jul-12 21:06 
Questiongreta article Pin
pritpalkaur15-May-12 15:19
pritpalkaur15-May-12 15:19 
GeneralMy Vote of 5 Pin
Shahin Khorshidnia12-May-12 19:37
professionalShahin Khorshidnia12-May-12 19:37 
GeneralMy vote of 5 Pin
sravani.v7-May-12 18:32
sravani.v7-May-12 18:32 
GeneralMy vote of 5 Pin
Manoj Kumar Choubey2-Apr-12 22:15
professionalManoj Kumar Choubey2-Apr-12 22:15 

General General    News News    Suggestion Suggestion    Question Question    Bug Bug    Answer Answer    Joke Joke    Praise Praise    Rant Rant    Admin Admin   

Use Ctrl+Left/Right to switch messages, Ctrl+Up/Down to switch threads, Ctrl+Shift+Left/Right to switch pages.