构建高性能ASP.NET站点 第五章—性能调优综述(后篇)

本文涉及的产品
公共DNS(含HTTPDNS解析),每月1000万次HTTP解析
云解析 DNS,旗舰版 1个月
全局流量管理 GTM,标准版 1个月
简介:
构建高性能ASP.NET 站点  第五章性能调优综述(后篇)
    前言:本篇主要讲述如何根据一些简单的工具和简单的现象来粗布的定位站点的性能问题。  
本章的议题如下:
性能调优的一般过程
利用分析工具分析页面加载信息
利用分析工具分析性能瓶颈
      利用分析工具分析性能瓶颈
    在上一节中,讲述了如何使用Firebug 来生成页面加载信息的瀑布图,同时也讲述了使得页面加载变慢的四个大的问题:
1.        服务端花费大量时间解析.aspx 时间过长。
2.        在服务端和浏览器之间,传递html 时间过长
3.        图片和flash 文件的加载时间过长
4.       Js css 的加载花费时间过长
    那么我们下面就根据瀑布图来判断:页面加载变慢,到底是因为哪个因素导致的。
 
1.        如何判断:服务端花费大量时间解析.aspx 时间过长
在下面的图示中,大家可以看到第一条时间线特别的长:其中紫色的那段表明了在浏览器接受到该页面的第一个字节之前等待的时间。也就是说,在浏览器请求Default.aspx 页面之后,浏览器一直处于等待状态。只有浏览器接受到了Default.aspx DOM 之后,才开始下载页面中的其他的资源(css, 图片等) 。如果在接受Default.aspx DOM 之前等待的时间过长,那么势必影响其他的资源的下载,最后导致整个页面的加载变慢。
 
如果我们在用firebug 生成瀑布图的时候,发现了上面的类似的现象,页面加载变慢的原因很有可能就是服务端在解析Default.aspx 页面,生成html 文本的时间太长了。至于是什么原因导致了服务端解析Default.aspx 时间过长,那么需要进一步的分析。可能是代码写的不好,例如循环问题;可能是数据库问题,例如查询数据太慢或者数据太多等(后续文章详细讲述)。   
 
注:颜色表示的意思:
 
 
2.        如何判断:在服务端和浏览器之间,传递html 时间过长
    在下面的图中,大家可以看到紫色的线段比较的短,也就是说,服务端解析Default.aspx 页面的时间还是比较短的,但是灰色的线段比较的长,。灰色的部分表示接受数据时间很长,也就是说服务端把DOM 发送到浏览器,这个过程耗时比较的长。正如之前的问题一样,这个问题也会推迟页面的其他的资源下载,导致整个页面加载过慢。导致这个问题的原因可能是带宽问题,可能是数据过多等。
 
3.        如何判断:图片和flash 等文件的加载时间过长
如下图所示,页面的解析和传送到客户端的时间比较的短,但是页面中的图片加载花费了大量的时间。现在的浏览器一般都会同时打开多个链接,并行的请求多个图片资源,而不是一个个的挨个请求。但是浏览器打开链接的数量是有限制的(不同的浏览器不一样),而且打开新的TCP 链接也是需要花时间的,不是链接越多越好。后面我们会讲述如何减少图片等资源的加载时间。
 
4.       如何判断:Jscss的加载花费时间过长,阻止页面的呈现
    如下图所示,在Default.aspx 页面载入之后,浏览器就开始解析DOM (从上到下解析,例如head -> body… , 下载资源。当页面解析到需要加载css js 时,此时浏览器就会去服务端请求这些文件,而用户在浏览器中看到的Default 页面将会是一片空白,一直到css js 载入完成之后,页面开始下载图片等,此时页面才会慢慢的呈现出来。
下图就反应了这个问题。
 
  
   今天就到这里了,从下一篇文章开始就全面进入分析和调优阶段。





















本文转自yanyangtian51CTO博客,原文链接: http://blog.51cto.com/yanyangtian/490821  ,如需转载请自行联系原作者


相关文章
|
5月前
|
消息中间件 Linux iOS开发
.NET 高性能异步套接字库,支持多协议、跨平台、高并发
【11月更文挑战第3天】本文介绍了高性能异步套接字库在网络编程中的重要性,特别是在处理大量并发连接的应用中。重点讨论了 .NET 中的 Socket.IO 和 SuperSocket 两个库,它们分别在多协议支持、跨平台特性和高并发处理方面表现出色。Socket.IO 基于 WebSocket 协议,支持多种通信协议和跨平台运行,适用于实时通信应用。SuperSocket 则通过事件驱动的异步编程模型,实现了高效的高并发处理,适用于需要自定义协议的场景。这些库各有特点,可根据具体需求选择合适的库。
119 6
|
11月前
|
开发框架 缓存 前端开发
利用Visual Basic构建高效的ASP.NET Web应用
【4月更文挑战第27天】本文探讨使用Visual Basic与ASP.NET创建高效Web应用的策略,包括了解两者基础、项目规划、MVC架构、数据访问与缓存、代码优化、异步编程、安全性、测试及部署维护。通过这些步骤,开发者能构建出快速、可靠且安全的Web应用,适应不断进步的技术环境。
147 0
|
7月前
|
前端开发 关系型数据库 MySQL
ThingsGateway:一款基于.NET8开源的跨平台高性能边缘采集网关
ThingsGateway:一款基于.NET8开源的跨平台高性能边缘采集网关
189 2
|
8月前
|
存储 监控 算法
内存泄漏还是高性能?深度揭秘.NET垃圾回收机制
【8月更文挑战第28天】垃圾回收是.NET框架中自动化内存管理的关键机制,它通过分代收集算法自动清理不再使用的对象,简化了开发者的内存管理工作。本文深入解析了垃圾回收器的工作原理、对象内存分配策略及优化技巧,并介绍了多种监控工具,帮助提升.NET应用性能与稳定性。掌握这些知识将使开发者能够更高效地管理内存,提高应用程序的运行效率。
89 3
|
8月前
|
开发者 Apache 程序员
揭秘Apache Wicket:页面生命周期背后的神秘力量!
【8月更文挑战第31天】李工是一位热爱Web开发的程序员,近日在技术博客上分享了他对Apache Wicket框架的学习心得,特别是页面生命周期的理解。他认为掌握Wicket页面生命周期对于开发富交互式Web应用至关重要。他通过一个简单的计数器应用示例,详细解释了Wicket的组件化设计理念以及页面和组件在生命周期中的变化。
81 0
|
8月前
|
存储 测试技术 C#
Blazor WebAssembly 开启离线应用开发新时代!C# 与.NET 助力,打造高性能跨平台新体验!
【8月更文挑战第31天】在互联网快速发展的今天,用户对Web应用体验的要求日益提高,尤其在无网络环境下使用应用的需求愈发明显。Blazor WebAssembly 应运而生,它基于 WebAssembly 技术,允许开发者利用 C# 和 .NET 构建交互式 Web 应用,无需服务器支持即可在浏览器中运行,从而实现离线使用。Blazor WebAssembly 具有使用熟悉的技术栈、高性能、离线支持以及跨平台等优势。开发者可通过安装开发工具、创建项目、编写代码、调试测试及发布应用几个步骤来进行开发。这为离线应用开发开启了新篇章。
233 0
|
11月前
|
机器学习/深度学习 存储 编解码
多任务学习新篇章 | EMA-Net利用Cross-Task Affinity实现参数高效的高性能预测
多任务学习新篇章 | EMA-Net利用Cross-Task Affinity实现参数高效的高性能预测
299 0