Presentation is loading. Please wait.

Presentation is loading. Please wait.

Best Practices for ASP.NET Development Ammar Abuthuraya Developer & Platform Lead Microsoft Corporation.

Similar presentations


Presentation on theme: "Best Practices for ASP.NET Development Ammar Abuthuraya Developer & Platform Lead Microsoft Corporation."— Presentation transcript:

1 Best Practices for ASP.NET Development Ammar Abuthuraya Developer & Platform Lead Microsoft Corporation

2 What we will cover  Designing ASP.NET Web forms  Use code-behind for best performance and scalability  ASP.NET caching techniques  State management options  Recommendations for communicating with COM components from ASP.NET

3 Session Prerequisites Level 300  Understand.NET architecture  Working knowledge of either VB.NET or C#  Knowledge of ASP.NET application architecture  Knowledge of ASP

4 So Why This Presentation?  You know how to build ASP applications and use the same techniques to build ASP.NET applications  You want to leverage the power and capabilities of ASP.NET  You want to use ASP.NET to build high- performance, scalable, web-based applications

5 Demonstrations  Language best practices  Server Control design practices  Component & user control design  State management recommendations  Caching techniques  Measuring performance

6 Agenda  Language and Code Practices  Server Control Design Practices  Component and User Control Usage Practices  State Management Recommendations  Deployment Best Practices  Measurement Techniques

7 Language and Code Practices Code Performance .NET Common Language Runtime (CLR) provides big runtime performance wins  Further optimize by native code generation using NGEN.EXE  No perf difference in.NET languages  Equivalent code written in VB and C# provides equivalent performance at runtime

8 Language and Code Practices Binding in VB.NET  Early binding in VB performs better than late binding ‘ VB Late Binding Example Dim j, obj obj = New System.Collections.ArrayList() for j = 0 To i obj.Add(j) obj.Add(j)Next ‘ VB Early Binding Example Dim j as integer, obj As ArrayList obj = New System.Collections.ArrayList() for j = 0 To i obj.Add(j) obj.Add(j)Next

9 Language and Code Practices Language Recommendations  Avoid using late binding in VB  Explicitly declare all variable types (Dim a as Long)  Avoid late bound methods on Object type  Use  Requires all variables to be declared (DIM required)  Still enables late bound code to exist though   Disallows any late bound code to be used

10 Language and Code Practices COM interop Issues  Apartment threaded components are particularly expensive in ASP.NET  ASP.NET now uses MTA thread pool by default that has very bad perf side effects when running STA components  This affects all VB6( STA) components!

11 Language and Code Practices interop Recommendations  Ideally migrate COM code to.NET  Alternatively structure APIs to be less “chatty” and more “chunky” in usage  Use COM interop through System.Runtime.interopServices  If using apartment components, mark page to run in STA compat mode: 

12 Language and Code Practices interop Recommendations  Be careful not to declare any STA component in “constructor” of page: Dim MyComponent as New MySTAComponent() 'Bad! Dim MyComponent as New MySTAComponent() 'Bad!</script> Dim MyComponent as MySTAComponent Dim MyComponent as MySTAComponent Sub Page_Load(Sender as Object, E as EventArgs) Sub Page_Load(Sender as Object, E as EventArgs) MyComponent = New MySTAComponent() MyComponent = New MySTAComponent() End Sub End Sub</script>

13 Demonstration 1 Language Best Practices Early binding vs. Late Binding Using COM objects in ASP.NET

14 Agenda  Language and Code Practices  Server Control Design Practices  Component and User Control Usage Practices  State Management Recommendations  Deployment Best Practices  Measurement Techniques

15 Server Control Design Practices Optimizing Server Control Rendering  Server controls provide a very clean programming model abstraction  Recommended way to build ASP.NET pages  Server controls do more rendering/postback work than old-style code  Should understand what this work is and optimize for it accordingly  Two areas to think about and optimize:  Rendering Content  ViewState Postback

16 Server Control Design Practices Optimizing Server Control Rendering  Server controls encapsulate rendering markup logic at runtime  Handle style and automatic uplevel/downlevel functionality management  individual server controls each add slight additional rendering cost  Additional allocations for style management  Additional allocations for control itself  Net take: the more individual server controls on page, the more this overhead can be noticed  Need to be especially aware of this w/ composite list controls that generate multiple controls per data row

17 Server Control Design Practices Optimizing Use of Viewstate  ASP.NET allows pages/controls to maintain state across round trips by storing state within hidden “viewstate” field  Disabled with “EnableViewState” attribute  Some downsides:  increases network payload  Performance overhead to serialize this  Recommendation:  Always review your usage of this feature  Always disable if you are not doing postback  Disable on per control basis if possible  Use to track usage size

18 Server Control Design Practices Data Validation Techniques  Leverage client side scripting capabilities to perform validations  Perform validation on both server & client side to avoid validation bypass  Make appropriate use of the RequiredFieldValidator  Use RegularExpressionValidator for validating complex field types like Credit Card

19 Server Control Design Practices Data Binding Best Practices  Multiple ways to do data access with.NET  SQL vs. OLEDB ADO.NET Provider  DataReaders vs. DataSets  Recommendations:  Always use SQL Data Provider for Microsoft ® SQL Server ™ data access  Use DataReaders for ASP.NET data access and use DataSets only when data caching or with web services

20 Demonstration 2 Server Control Design Practices Optimizing Server Control Rendering Optimizing Use of Viewstate Data Validation Best Practices Data Binding Best Practices

21 Agenda  Language and Code Practices  Server Control Design Practices  Component and User Control Usage Practices  State Management Recommendations  Deployment Best Practices  Measurement Techniques

22 Component & User Control Practices Improving User Experience  ASP.NET built-in caching features  Output Caching  Fragment Caching  Caches the static result of an ASP.NET page  Use the directive to control caching behavior

23 Component & User Control Practices Improving User Experience  Caching Options:  Duration - Time item exists in the cache  VaryByParam - Varies cache entries by Get/Post params. Name param, separate by semi-colons, supports *  VaryByHeader - Varies cache entries by Http header  VaryByCustom - Override method within Global.asax to custom vary by whatever you want (you control the cache key)

24 Component & User Control Practices Improving User Experience  Caching the entire page isn’t always possible  Partial page personalization, etc.  Fragment Caching allows caching regions of a page by using user controls (.ascx)  User controls define directive

25 Component & User Control Practices Coding Patterns in ASP.NET  Common coding patterns:  Spaghetti – include all presentation logic and code in the same page like classic ASP  Code behind – all presentation logic is in the aspx file, which is linked to a separate code behind file  Component – business logic is present in a compiled component, which is invoked for providing various services  There is no perf difference between a dynamically compiled.aspx (“spaghetti”) and “code behind” style page

26 Component & User Control Practices Optimizing Data Flow Across Tiers  Data exchange across tiers has to be optimized for the deployment scenario  Avoid passing datasets across tiers  Use DataReaders for fast, forward-only access to the data stream  XML is very verbose; suitable for communications with unknown systems

27 Component & User Control Practices Optimizing Data Flow Across Tiers  Minimize the number of post backs  Leverage client side capabilities to avoid post backs  Control the amount of view state information passed during a post back  Use EnableViewState at page or control level to configure view state usage.

28 Demonstration 3 Component & User Control Best Practices Buffered Output Fragment Caching & Custom Caching Code Behind, User Controls & Components Data Flow Across Tiers Optimizing Postback

29 Agenda  Language and Code Practices  Server Control Design Practices  Component and User Control Usage Practices  State Management Recommendations  Deployment Best Practices  Measurement Techniques

30 State Management Recommendations in Proc Session State  Session state is stored in the ASP.NET worker process  Recycling the process will cause all session state to be lost  Session state performance is maximum in this mode

31 State Management Recommendations Out of Proc Session State  Session state can be stored in a State server process running on the same machine or a different machine  State can also be stored in a SQL Server database  Restarting the web server does not cause the session state to be lost  More reliable than in process session state but less performant

32 State Management Recommendations Configuring Session State  Session state can be configured via the element in the web.config file  Change causes ASP.NET application to be restarted, all new sessions will be stored as per the updated session configuration  Out of process session state stores like State Server or SQL Server must be started & configured properly

33 Demonstration 4 State Management Best Practices State Management Session State in A State Server

34 Agenda  Language and Code Practices  Server Control Design Practices  Component and User Control Usage Practices  State Management Recommendations  Deployment Best Practices  Measurement Techniques

35 Deployment Best Practices Logical Design  Design your applications using logical 3-Tier Design Practices:  Pages (.aspx) and User Controls (.ascx)  Reusable Biz Classes in \bin dir (.vb +.cs)  Data within a SQL Database  Design your Web application so that it can be distributed across a Web farm  Your code shouldn’t assume that a client will always return to the same machine  Be careful of assumptions regarding statics and application state

36 Deployment Best Practices Physical Deployment  Deploy your applications such that the pages and components run in same process  Deploying onto remote servers connected via DCOM or Web Services will almost always hurt your performance/scalability  Leverage Web services only for application to application communication -- not intra app calls  Leverage ISA Server for configurations where a DMZ security zone is required  Enables you to restrict app server access from browser clients

37 Deployment Best Practices ISA for DMZ Configurations ISA ASP.NET SQL DMZ (firewalled) Browsers

38 Agenda  Language and Code Practices  Server Control Design Practices  Component and User Control Usage Practices  State Management Recommendations  Deployment Best Practices  Measurement Techniques

39 Measurement Techniques Overview of Application Center Test  Application Center Test (ACT) is a tool designed for stress testing web servers  The tool assists in determining performance and scalability of a given web site  The tool also collect useful statistical information during the stress test  ACT also exposes a programming interface, which can be used for creating stress test scripts

40 Measurement Techniques Key Performance indicators  The key performance indicators of a web application are:  Processor utilization  Low value indicates blocking on other resources  ASP.NET  Requests/Sec & Requests Queued  Memory  Pages Faults/Sec – lower the better, high numbers indicate insufficient memory condition

41 Measurement Techniques Stress Testing  Stress testing is a defensive mechanism to creating scalable web sites  Stress runs will indicate the scalability of the application  Can be used to determine scale of operation, when to add new hardware etc  Stress testing should not be the final step in building a web application. It should be integrated into the development life cycle  Narrow the scope of a stress run to get more accurate, actionable results

42 Measurement Techniques Stress Testing  Use the web site logs to determine operational load  Stress tools like WAS (“Homer”) allow log files to be “replayed” on a web site and record statistical performance information  Run performance monitoring tools on the live servers to identify scalability issues

43 Measurement Techniques Designing Scalable Applications  Two ways to quantify Web performance:  Machine Throughput (requests/sec)  Response Time (time to first/last bytes)  Measure performance by stressing server  Utilize multiple client stress machines  Use Application Center Test tool  Measure multiple scenarios:  Simulate end to end scenario walkthroughs of site  Measure individual page performances

44 Demonstration 5 Measurement Techniques Performance Measurement

45 Session Summary  in this session we discussed:  Language and Code Practices  Server Control Design Practices  Component and User Control Usage Practices  State Management Recommendations  Caching Techniques  Deployment Best Practices  Measurement Techniques

46 for More information…  MSDN Web site at  msdn.microsoft.com

47 Training & Events MSDN Webcasts, MSDN Online Seminars, Tech-Ed, PDC, Developer Days MSDN Essential Resources for Developers Subscription Services Online information Membership Programs Print Publications Library, OS, Professional, Enterprise, Universal Delivered via CD-ROM, DVD, Web MSDN Online, MSDN Flash, How-To Resources, Download Center MSDN User Groups MSDN Magazine MSDN News

48 How-To Resources Simple, Step-By-Step Procedures  Embedded Development How-To Resources  General How-To Resources  integration How-To Resources  JScript.NET How-To Resources .NET Development How-To Resources  office Development Resources  Security How-To Resources  Visual Basic ®.NET How-To Resources  Visual C# ®.NET How-To Resources  Visual Studio ®.NET How-To Resources  Web Development How-To Resources (ASP, IIS, XML)  Web Services How-To Resources  Windows ® Development How-To Resources http://msdn.microsoft.com/howto

49 MSDN Webcasts interactive, Live Online Event  interactive, Synchronous, Live Online Event  Discuss the Hottest Topics from Microsoft  Open and Free for The General Public  Takes Place Every Tuesdays http://www.microsoft.com/usa/webcasts

50 MSDN Subscriptions THE way to get Visual Studio.NET Visual Studio.NET MSDN Subscriptions NEW Professional Tools to build applications and XML Web services for Windows and the WebTools to build applications and XML Web services for Windows and the Web MSDN Professional $1199 new $899 renewal/upgrade MSDN Enterprise $2199 new $1599 renewal/upgrade MSDN Universal $2799 new $2299 renewal/upgrade Enterprise Developer Enterprise lifecycle toolsEnterprise lifecycle tools Team development supportTeam development support Core.NET Enterprise ServersCore.NET Enterprise Servers Enterprise Architect Software and data modelingSoftware and data modeling Enterprise templatesEnterprise templates Architectural guidanceArchitectural guidance

51 Where Can I Get MSDN?  Visit MSDN Online at msdn.microsoft.com  Register for the MSDN Flash Email Newsletter at msdn.microsoft.com/flash  Become an MSDN CD Subscriber at msdn.microsoft.com/subscriptions  MSDN online seminars msdn.microsoft.com/training/seminars  Attend More MSDN Events

52 MS Press Essential Resources for Developers Microsoft® Visual Studio®.NET is here! This is your chance to start building the next big thing. Develop your.NET skills, increase your productivity with.NET Books from Microsoft Press® www.microsoft.com/mspress

53 Training Training Resources for Developers  Course Title: introduction to Microsoft ASP.NET  Course Number:2063  Availability: Now  Detailed Syllabus: www.microsoft.com/traincertwww.microsoft.com/traincert To locate a training provider for this course, please access www.microsoft.com/traincert Microsoft Certified Technical Education Centers are Microsoft’s premier partners for training services

54 Become A Microsoft Certified Solution Developer  What is MCSD?  Microsoft Certified Solution Developer  The premier certification for lead developers who design and develop leading-edge enterprise solutions with Microsoft development tools, technologies, and the Microsoft.NET Framework.  How do I attain the MCSD for Microsoft.NET certification?  4 core exams  1 elective exam  For complete information visit: www.microsoft.com/mcsd www.microsoft.com/mcsd


Download ppt "Best Practices for ASP.NET Development Ammar Abuthuraya Developer & Platform Lead Microsoft Corporation."

Similar presentations


Ads by Google