Introduction
Before i start session, i strongly recommended you to read following Blogs in given serial first,
- Web server and IIS
- Worker Process and Application Pool
Now,
I have covered all the basic stuff like Web server, Application Pool, Worker process. Now let’s have look how IIS process the request when a
new request comes up from client.
If we look into the IIS 6.0 Architecture, we can divided them into Two Layer
1. Kernel Mode
2. User Mode
Kernel mode is introduced with IIS 6.0, which contains the HTTP.SYS. So whenever a request comes from Client to Server, it will hit HTTP.SYS First.
Now, HTTP.SYS is Responsible for pass the request to particular Application pool. Now here is one question, How HTTP.SYS comes to know where to send the request? This is not a random
pickup. Whenever we creates a new Application Pool, the ID of the
Application Pool is being generated and it’s registered with the
HTTP.SYS. So whenever HTTP.SYS Received the request from any web
application, it checks for the Application Pool and based on the
application pool it send the request.
So, this was the first steps of IIS Request Processing.
Till
now, Client Requested for some information and request came to the
Kernel level of IIS means at HTTP.SYS. HTTP.SYS has been identified the
name of the application pool where to send. Now, let’s see how this
request moves from HTTP.SYS to Application Pool.
User Level of IIS, we have Web Admin Services (WAS) which takes the request from HTTP.SYS and pass it to the respective application pool.
When Application pool receive the request, it simply pass the request to worker process (w3wp.exe). The worker process “w3wp.exe”
looks up the URL of the request in order to load the correct Internet Service Application program Interface
extension. .aspx , .asmx, .ashx are different
ISAPI extension. ISAPI extensions are the IIS way to handle requests for
different resources. Once ASP.NET is installed, it installs its own
ISAPI extension (aspnet_isapi.dll) and adds the mapping into IIS.
Note : Sometimes if we install IIS after installing asp.net, we need to register the extension with IIS using aspnet_regiis command.
When Worker process loads the aspnet_isapi.dll, it start an HTTPRuntime, which is the entry point of an application. HTTPRuntime is a class which calls the ProcessRequest method to start Processing.When this methods called, a new instance of HTTPContext is been created. Which is accessible using HTTPContext.Current properties. This object still remains alive during life time of object
request. Using HttpContext.Current we can access some other
objects like Request, Response, Session etc.
After that HttpRuntime load an HttpApplication object with the help of HttpApplicationFactory class..
Each and every request should pass through the corresponding HTTPModule
to reach to HTTPHandler, this list of module are configured by the
HTTPApplication.
Now, the concept comes called “HTTPPipeline”.
It is called a pipeline because it contains a set of HttpModules ( For
Both Web.config and Machine.config level) that intercept the
request on its way to the HttpHandler. HTTP modules inspect the incoming request and depending on that, they can change the internal workflow of the request. We can also create our own HTTPModule
if we need to handle anything during upcoming request and response.
HTTP Handlers are the endpoints in the HTTP pipeline.
All request that are passing through the HTTPModule should reached to
HTTPHandler.Then HTTP Handler generates the output
for the requested resource. HTTP handler actually compiles the page and generates output. So, when we requesting for any aspx web
pages, it returns the corresponding HTML output.
All the request now passes from httpModule to respective
HTTPHandler then method and the ASP.NET Page life cycle starts. This ends the IIS Request processing and start the ASP.NET Page
Lifecycle.
If you see your machine.config file you will see following section of HTTP modules
<httpModules>
<add name="OutputCache" type="System.Web.Caching.OutputCacheModule" />
<add name="Session" type="System.Web.SessionState.SessionStateModule" />
<add name="WindowsAuthentication" type="System.Web.Security.WindowsAuthenticationModule" />
<add name="FormsAuthentication" type="System.Web.Security.FormsAuthenticationModule" />
<add name="PassportAuthentication" type="System.Web.Security.PassportAuthenticationModule" />
<add name="UrlAuthorization" type="System.Web.Security.UrlAuthorizationModule" />
<add name="FileAuthorization" type="System.Web.Security.FileAuthorizationModule" />
<add name="ErrorHandlerModule" type="System.Web.Mobile.ErrorHandlerModule,
System.Web.Mobile, Version=1.0.5000.0,
Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a" />
</httpModules>
The above mapping will show which Namespace handles which functionality.
HTTP handler is where the actual compilation takes place and the
output is generated. Following is a paste from HTTP handler section of
WEB.CONFIG file.
<httpHandlers>
<add verb="*" path="*.vjsproj" type="System.Web.HttpForbiddenHandler" />
<add verb="*" path="*.java" type="System.Web.HttpForbiddenHandler" />
<add verb="*" path="*.jsl" type="System.Web.HttpForbiddenHandler" />
<add verb="*" path="trace.axd" type="System.Web.Handlers.TraceHandler" />
<add verb="*" path="*.aspx" type="System.Web.UI.PageHandlerFactory" />
<add verb="*" path="*.ashx" type="System.Web.UI.SimpleHandlerFactory" />
...
</httpHandlers>
•
Depending on the File extension handler decides which Namespace will
generate the output. Example all .ASPX extension files will be compiled
by System.Web.UI.PageHandlerFactory
• Once the file is compiled it will be send back again to the HTTP modules and from there to IIS and then to the browser.