Skip to main content

Asp.Net 4.0: An Overview-Part-II

This post is in continuation with the series started in my earlier post and continues to explore the remaining features as described in the post.
Let’s start by considering the point 2 in the earlier post i.e. Shrinking Session State

Shrinking Session State
 ASP.NET (3.5) provides two default options for storing session state across a Web farm:
a session-state provider that invokes an out-of-process session-state server, and a session-state provider that stores data in a Microsoft SQL Server database.session state has to be serialized before it is sent to remote as both options involve storing state information outside a Web application's worker process
the size of the serialized data can grow quite large as more data is added to the session state.
ASP.NET 4 introduces a new compression option(compressionEnabled) .When this configuration option is set to true, ASP.NET will compress (and decompress) serialized session state by using the .NET Framework System.IO.Compression.GZipStream class.
This is depicted below.

<sessionState mode="SqlServer" sqlConnectionString="data source=dbserver;Initial Catalog=aspnetstate"  allowCustomSqlDatabase="true"  compressionEnabled="true"
/>

This seems like an excellent enhancement for making the Performance related issues a bit easier to tackle.
The next Enhancement will definitely add a lot in improving the performance of the applications. This is the Enhancement in Enabling/Disabling the Viewstate for Individual Controls.
Now the question raised, Is that really an enhancement. The answer is YES. This feature exists in the current 3.5 version also, however the enhancement in version 4.0 makes it a lot easier to manage.Let me explain it in detail.

Enabling View State for Individual Controls
In ASP.Net 3.5 and earlier Versions, view state is enabled for the page, with the result that each control on the page potentially stores view state. The View state is  stored for each control  even  if it is not required for the application.
Why should we bother about the View state data?
View State data is included in the markup that a page generates and increases the amount of time it takes to send a page to the client and post it back. Now consider that all the controls save view state and  it is not used in any processing. It will cause significant performance degradation.
Developers can disable view state for individual controls in order to reduce page size, but need to do it explicitly for individual controls.
 In ASP.NET 4, all web server controls include a ViewStateMode property. This property disables view state by default and can be enabled  for the controls that require it in the page.
The ViewStateMode property takes an enumeration that has three values: Enabled, Disabled, and Inherit.

 Enabled enables view state for that control and for any child controls that are set to Inherit or that have nothing set.

Disabled disables view state, and Inherit specifies that the control uses the ViewStateMode setting from the parent control.

Let’s consider the Following Example
<form id="form1" runat="server">
   <script runat="server">
protected override void OnLoad(EventArgs e) {
if (!IsPostBack) {
label1.Text = label2.Text = "Some Dynamic Value";
}
base.OnLoad(e);
}
</script>
  <asp:PlaceHolder ID="plHolder1" runat="server" ViewStateMode="Disabled">Disabled:
   <asp:Label ID="lblTest" runat="server" Text="ViewStateDisbaled" /><br />
  <asp:PlaceHolder ID=" plHolder2" runat="server" ViewStateMode="Enabled"> Enabled:
<asp:Label ID="lblTest2" runat="server" Text="ViewStateEnabled" />
  </asp:PlaceHolder>
</asp:PlaceHolder>
  <hr />
<asp:button ID="Button1" runat="server" Text="Postback" />
 
In the Code above, view state for the plHolder1 control is disabled. The child label lblTest control inherits this property value (Inherit is the default value for ViewStateMode for controls.) and therefore saves no view state. In the plHolder2 control, ViewStateMode is set to Enabled, so lblTest2 inherits this property and saves view state.
The lblTest control (whose ViewStateMode value is set to Disabled) does  not preserved the value that it was set to in code. However, the lblTest2 control (whose ViewStateMode value is set to Enabled) preserves  its state.
ViewStateMode can also be set in @ Page directive
<%@ Page Language="C#" AutoEventWireup="true” CodeBehind="Default.aspx.cs"
Inherits="MyWebApp._Default" ViewStateMode="Disabled" %>

The Page class is just another control; it acts as the parent control for all the other controls in the page. The default value of ViewStateMode is Enabled for instances of Page. Because controls default to Inherit, controls will inherit the Enabled property value unless you set ViewStateMode at page or control level.
Having said the above point, let me emphasize here that the EnableViewState property of the Page still holds the upper hand i.e. If the EnableViewState is set to False and ViewStateMode is set to Enabled, no control will save the View state.

I’ll continue to explore the remaining Enhancements in the Next post.
Till Next we connect……

Happy Learning

Comments

Popular posts from this blog

Asp.Net 4.0: An Overview-Part-III

This is the last post in the series which will explore the following new features of ASP.Net 4.0  Performance Monitoring for Individual Applications in a Single Worker Process Web.config File Refactoring Permanently Redirecting a Page Expanding the Range of Allowable URLs Performance Monitoring for Individual Applications in a Single Worker Process It is a common practice to host multiple ASP.NET applications in a single worker process, In order to increase the number of Web sites that can be hosted on a single server. This practice results in difficulties for server administrators to identify an individual application that is experiencing problems. ASP.NET 4 introduces new resource-monitoring functionality introduced by the CLR. To enable this functionality, following XML configuration snippet is added to the aspnet.config configuration file.(This file is located in the directory where the .NET Framework is installed ) <?xml version="1.0" encoding="UTF-8...

Covariance and Contravariance-General Discussion

If you have just started the exploration of .Net Framework 4.0, two terms namely Covariance and Contravariance might have been heard. The concept that these terms encapsulate are used by most developer almost daily, however there has never been any botheration about the terminologies. Now, what actually these terms mean and how are these going to affect us as a developer, if we dive in to the details. The simple answer is it’s always good to know your tools before actually using them. Enough philosophy, let’s get to the business. Starting the discussion let me reiterate that in addition to Covariance and Contravariance, there is another terminology, Invariance. I’ll by start here by diving into the details of Invariance and then proceed further. Invariance: Invariance can be better understood by considering the types in .Net.>net has basically two type, value-types and reference-types. Value types (int, double etc) are invariant i.e. the types can’t be interchanged either ...

Advanced WCF

In this post, I am sharing the link of articles about  advanced topics in WCF. The List of articles is exhaustive and can serve as your repository for all WCF queries. Concurrency,Throttling & Callbacks  WCF Concurrency (Single, Multiple and Re entrant) and Throttling   WCF-Interop and BinarySecurityToken  WCF Callbacks  Creating Web Services From WSDL Link1 Link2 Link3 Link4 WCF-Security WCF over HTTPS   Transport Security(basic)/HTTPS UserNamePasswordValidator ServerCertificateValidationCallback 9 simple steps to enable X.509 certificates on WCF - CodeProject http://www.codeproject.com/KB/WCF/9StepsWCF.aspx?display=Print Message Security(Certificate)/PeerTrust Securing WCF Services with Certificates. - CodeProject http://www.codeproject.com/KB/WCF/wcf_certificates.aspx Message Security(Certificate)/ChainTrust How To Configure WCF Security Using Only X.509 Certificates - CodePr...