给web网页加上生成时间,并在页面方法执行或者控件方法执行中查找性能瓶颈
在很多时候我们需要调整网站的性能,通过iis日志分析网站的执行速度,在执行速度有问题时,我们不得不调试,调试的时候就用到了当前页面的执行时间。
我站点中的所有网页都从一个PageBase继承,所以我把统计执行时间的功能放到了PageBase中,首先我声明一个long类型的成员变量_startTimeTicks,此成员变量记录开始执行的时间Tick,在页面Render完成时我再用DateTime.Now.Ticks减去开始的startTimeTicks,这样便得到了整个页面的执行时间。
1 public class PageBase : Page
2 {
3 protected long _startTimeTicks;
4
5 protected override void OnInit(EventArgs e)
6 {
7 _startTimeTicks = DateTime.Now.Ticks;
9
10 base.OnInit(e);
11 }
12
13 #region 执行时间
14 public string ExecTime
15 {
16 get
17 {
18 TimeSpan ts = new TimeSpan(DateTime.Now.Ticks - _startTimeTicks);
19 return ts.TotalMilliseconds.ToString() + "ms";
20 }
21 }
22
23 public int ExecTimeTicks
24 {
25 get
26 {
27 long ticks = DateTime.Now.Ticks - _startTimeTicks;
28 return ticks;
29 }
30 }
31 #endregion
32 }
33
2 {
3 protected long _startTimeTicks;
4
5 protected override void OnInit(EventArgs e)
6 {
7 _startTimeTicks = DateTime.Now.Ticks;
9
10 base.OnInit(e);
11 }
12
13 #region 执行时间
14 public string ExecTime
15 {
16 get
17 {
18 TimeSpan ts = new TimeSpan(DateTime.Now.Ticks - _startTimeTicks);
19 return ts.TotalMilliseconds.ToString() + "ms";
20 }
21 }
22
23 public int ExecTimeTicks
24 {
25 get
26 {
27 long ticks = DateTime.Now.Ticks - _startTimeTicks;
28 return ticks;
29 }
30 }
31 #endregion
32 }
33
这样PageBase基类就有了,他里面有两个Public的属性,可以随时记录执行到某个方法的时间段,这样对于调试程序,查看性能瓶颈很有用。
1 public class _Default:PageBase
2 {
3 protected void Page_Load(object sender, EventArgs e)
4 {
5 SomeClassInstance.method();
6 #if DEBUG
7 this.Controls.Add(new LiteralControl(ExecTime));
8 #endif
9 SomeClassInstance.methodA();
10 #if DEBUG
11 this.Controls.Add(new LiteralControl(ExecTime));
12 #endif
13 }
14 }
同样如果怀疑某个控件的执行中有可能有性能瓶颈,也可以统计它的方法的执行时间
2 {
3 protected void Page_Load(object sender, EventArgs e)
4 {
5 SomeClassInstance.method();
6 #if DEBUG
7 this.Controls.Add(new LiteralControl(ExecTime));
8 #endif
9 SomeClassInstance.methodA();
10 #if DEBUG
11 this.Controls.Add(new LiteralControl(ExecTime));
12 #endif
13 }
14 }
public class ControlA : UserControl
{
protected PageBase PageBase
{
get
{
return Page as PageBase;
}
}
protected override void OnLoad(EventArgs e)
{
SomeMethodA();
this.Controls.Add(new LiteralControl(PageBase.ExecTime));
SomeMethodB();
this.Controls.Add(new LiteralControl(PageBase.ExecTime));
base.OnLoad(e);
}
}
{
protected PageBase PageBase
{
get
{
return Page as PageBase;
}
}
protected override void OnLoad(EventArgs e)
{
SomeMethodA();
this.Controls.Add(new LiteralControl(PageBase.ExecTime));
SomeMethodB();
this.Controls.Add(new LiteralControl(PageBase.ExecTime));
base.OnLoad(e);
}
}
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 地球OL攻略 —— 某应届生求职总结
· 提示词工程——AI应用必不可少的技术
· Open-Sora 2.0 重磅开源!
· 周边上新:园子的第一款马克杯温暖上架