给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);
}
}