1. 概述

  常见的几种运行时问题包括 错误数据、慢于预期的响应、未知行为 或者 未处理的异常。

  Visual Studio 提供了 排查、跟踪 和 日志 等工具 来帮助排查系统的问题。有些情况还需要插入诊断代码。

  本章内容包括:排查性能、安全问题和运行时错误, 实现跟踪、日志(包括使用attributes) 和 调试(包括 IntelliTrace),使用代码契约来加强条件验证,启用和配置健康监视。

2. 主要内容

  2.1 排查性能问题、安全问题和运行时错误

    性能问题会让用户有挫败感

    安全问题可能会导致一切的问题,包括内部和外部的,如果用户的数据受到安全威胁的话。

    运行时错误会影响所有,包括 表现、安全 和 生成不正确的数据。

    2.1.1 使用性能向导(Performance Wizard)

      VS2012提供的性能向导,是一个性能分析工具。

      包含 CPU sampling、Instrumentation、.NET memory allocation (sampling) 和 Resource contention data (concurrency)。

      

      CPU sampling: 是一种轻量级的监测,更多的用于初始检查,提供进一步系统检查的方向。

      Instrumentation:方法调用的计数和时间。是一种更加侵入性的过程,性能工具会添加监测代码到组件中。

      .NET memory allocation (sampling): 监测内存分配。分析每一个对象从被创建到被回收的过程。

      Resource contention data (con-currency):用于多线程程序。提供线程交互信息以及线程与系统交互的信息。

    2.1.2 使用 Visual Studio Profiler

      Visual Studio 提供了一个 Profiler,提供了对系统中调用操作的完成跟踪信息。

      相对于性能监测工具对性能的关注,Visual Studio Profiler 主要监测活动并且记录它们。这种详细的数据,可以用来做更深入的分析。  

      

      这个图标展示了每秒钟Cpu的使用情况。

    2.1.3 使用 性能监测器(Performance Monitor)

      性能监测器是 Windows Server 提供的工具,可用于在生产环境监测程序。

      

  2.2 排查安全问题

    一般来说,安全问题都与 身份验证 和 授权访问 有关。

    身份验证问题,需要考虑验证问题的范围,是 所有用户、特定的一个用户 还是 一组用户。

    授权访问问题,也是类似的思路。根据范围确定问题可能发生的原因。

  2.3 实现 跟踪、日志 以及 调试

    跟踪 是一种 可以在程序运行时进行分析的技术。 .net內建了对跟踪的支持。

 Trace.WriteIf(someValueIsTrue, “Message”).

    日志 是记录信息的过程。NLog 和 log4net 是两种常用的开源日志工具。

    可以使用try-catch手动处理 调试、错误 和 跟踪信息,也可以通过使用 HandleErrorAttribute 来自动处理。

     HandleErrorAttribute 可用于 actions, controllers, 或者 globally。

[HandleError(ExceptionType=typeof(System.IOException),View="FileError")]

    

protected override void OnException(ExceptionContext exceptionContext)
{
if (exceptionContext.IsChildAction)
{
//we don't want to display the error screen if it is a child action,
base.OnException(exceptionContext);
return;
} // log the exception in your configured logger
Logger.Log(exceptionContext.Exception); //handle when the app is not configured to use the custom error path
if (!exceptionContext.HttpContext.IsCustomErrorEnabled)
{
exceptionContext.ExceptionHandled = true;
this.View("ErrorManager").ExecuteResult(this.ControllerContext);
}
}

  2.4 使用代码契约来加强条件验证

    代码契约在.net4.0中引入,允许开发者在程序中加入限制条件。包括三种类型:

    a. Preconditions 方法执行前,验证输入的条件。

    b. Invariants 方法执行过程中,防止出现非法的状态。

    c. Postconditions 方法完成时,检查要输出的结果。

    使用代码契约需要一种不同的方式去管理异常处理流程。

internal Article GetArticle(int id)
{
System.Diagnostics.Contracts.Contract.Requires(id > );
// some work here
}

    Invariant检查用于确保类中不会出现非法的状态。

[ContractInvariantMethod]
protected void ManageInvariant()
{
System.Diagnostics.Contract.Invariant(this.Id < );
}

    Postconditions

internal Article GetArticle(int id)
{
System.Diagnostics.Contracts.Contract.Requires(id > );
System.Diagnostics.Contracts.Contract.Ensures(
Contract.Results<Article>() != null);
// some work here
}

    还可以用其他方式处理违反合约的情况,可以通过注册 Contract.ContractFailed 事件,来添加自定义的处理逻辑。

  2.5 启用和配置健康监视

    健康监视(Health monitoring) 是ASP.NET中的子系统,是为了处理各种web事件的日志记录而设计的。比如 应用程序生命周期事件、安全事件 和 程序错误。

    健康监视(Health monitoring) 的好处包括:

    a. ASP.NET平台內建,访问性高于其他第三方组件。

    b. 遵从MS framework的标准,可以通过配置添加到程序中。

    c. 支持多种日志源(Microsoft SQL Server, the Windows Event Log, email)以及多种日志文件格式。

    通知配置,每种日志事件都可以被以不同的方式处理。

<healthMonitoring>
<bufferModes>
<add name="Critical Notification" maxBufferSize="100" maxFlushSize="20"
urgentFlushThreshold="1" regularFlushInterval="Infinite"
urgentFlushInterval="00:01:00" maxBufferThreads="1" />
<add name="Logging" maxBufferSize="1000" maxFlushSize="200"
urgentFlushThreshold="800" regularFlushInterval="00:30:00"
urgentFlushInterval="00:05:00" maxBufferThreads="1" />
</bufferModes>
<providers>
<add name="EventLogProvider"
type="System.Web.Management.EventLogWebEventProvider, System.Web" />
</providers>
<profiles>
<add name="Default" minInstances="1" maxLimit="Infinite"
minInterval="00:01:00" custom="" />
<add name="Critical" minInstances="1" maxLimit="Infinite"
minInterval="00:00:00" custom="" />
</profiles>
<rules>
<add name="All Errors Default" eventName="All Events"
provider="EventLogProvider" profile="Default" minInstances="1"
maxLimit="Infinite" minInterval="00:01:00" custom="" />
<add name="Failure Audits Default" eventName="App Lifetime Events"
provider="EventLogProvider" profile="Default" minInstances="1"
maxLimit="Infinite" minInterval="00:01:00" custom="" />
</rules>
<eventMappings>
<add name="All Events" type="System.Web.Management.WebBaseEvent,System.Web"
startEventCode="0" endEventCode="2147483647" />
<add name="Heartbeats" startEventCode="0" endEventCode="2147483647"
type="System.Web.Management.WebHeartbeatEvent,System.Web" />
<add name="App Lifetime Events" startEventCode="0" endEventCode="2147483647"
type="System.Web.Management.WebApplicationLifetimeEvent" />
</eventMappings>
</healthMonitoring>

      <bufferModes>节点用来定义事件被阻塞的时间长度。

      <providers> 提供了一组参数,可以设置 最小和最大实例数 等。

      <rules>节点 在 provider 和 event 之间创建关联。

      <eventMappings>节点 显示了程序映射的三种方式 all events, heartbeats, 和 application lifetime events。

3. 总结

  1) ASP.NET MVC 目的就是让用户去完成一系列的工作任务。程序设计应该使任务简化。程序性能是用户体验的一个核心组成部分,会在多个方面影响用户体验。

  2) 排查性能问题是使得程序更加健壮的核心。Visual Studio 提供的性能向导可以在  CPU, memory, 和 resource/threading 方面收集相关信息。根据这些信息,可以去排查程序可能存在的逻辑问题,比如 方法被调用太多次 等。

  3) Windows系统提供的性能监测工具,也可以在多个方面提供运行程序的相关信息。

  4) System.Diagnostics 下的 Tracing,可以记录信息到一个或多个 TraceListeners。需要的话,还可以创建自定义的TraceListener。

  5) Logging是用来捕捉程序信息的。可以使用第三方组件 NLog 或 log4net,或者使用System.Diagnostics命名空间来捕获和记录信息。

  6) 代码契约 是 用来 强化方法定义 和 发布内部条件验证 的一种方式。这些条件包括 preconditions、invariant 和  postconditions。

  7) Health monitoring是ASP.NET中的一个系统,用来 跟踪程序中的各种事件。通过配置文件来配置。

第十九章 排查和调试Web程序 之 防止和排查运行时问题的更多相关文章

  1. 第二十章 排查和调试Web程序 之 设计异常处理策略

    1. 概述 本章内容包括: 多层架构中的异常处理.使用global.asax 或 自定义的HttpHandler 或 web.config中的属性来显示特定的错误页.处理 first chance 异 ...

  2. 第十九章——使用资源调控器管理资源(1)——使用SQLServer Management Studio 配置资源调控器

    原文:第十九章--使用资源调控器管理资源(1)--使用SQLServer Management Studio 配置资源调控器 本系列包含: 1. 使用SQLServer Management Stud ...

  3. Gradle 1.12翻译——第十九章. Gradle 守护进程

    有关其他已翻译的章节请关注Github上的项目:https://github.com/msdx/gradledoc/tree/1.12,或访问:http://gradledoc.qiniudn.com ...

  4. 20190908 On Java8 第十九章 类型信息

    第十九章 类型信息 RTTI(RunTime Type Information,运行时类型信息)能够在程序运行时发现和使用类型信息. Java 主要有两种方式在运行时识别对象和类信息: "传 ...

  5. Python之路【第十九章】:Django进阶

    Django路由规则 1.基于正则的URL 在templates目录下创建index.html.detail.html文件 <!DOCTYPE html> <html lang=&q ...

  6. 第十九章——使用资源调控器管理资源(2)——使用T-SQL配置资源调控器

    原文:第十九章--使用资源调控器管理资源(2)--使用T-SQL配置资源调控器 前言: 在前一章已经演示了如何使用SSMS来配置资源调控器.但是作为DBA,总有需要写脚本的时候,因为它可以重用及扩展. ...

  7. 第十九章 Django的ORM映射机制

    第十九章 Django的ORM映射机制 第一课 Django获取多个数据以及文件上传 1.获取多选的结果(checkbox,select/option)时: req.POST.getlist('fav ...

  8. Gradle 1.12用户指南翻译——第四十九章. Build Dashboard 插件

    本文由CSDN博客貌似掉线翻译,其他章节的翻译请参见: http://blog.csdn.net/column/details/gradle-translation.html 翻译项目请关注Githu ...

  9. Gradle 1.12用户指南翻译——第二十九章. Checkstyle 插件

    其他章节的翻译请参见: http://blog.csdn.net/column/details/gradle-translation.html 翻译项目请关注Github上的地址: https://g ...

随机推荐

  1. 1076 Forwards on Weibo (30)(30 分)

    Weibo is known as the Chinese version of Twitter. One user on Weibo may have many followers, and may ...

  2. bzoj4453

    单调栈+set+后缀数组 一道奇妙的题 这道题如果对于每个询问$r$是固定的,那么就很简单了,可惜并不是 由于r会变化,那么对于两个子串$[i...r],[j...r]$,他们的大小关系随着r的变化也 ...

  3. PDF,IMAGE,HTML,WORD,EXCEL 互操作

    http://www.cnblogs.com/lyl6796910/p/3318056.html

  4. oracle 内连接 外连接 查询 笔记

    elect ename,job,sal from emp where deptno>10 order by sal desc; 联合查询,PK dept.deptno FK emp.deptno ...

  5. [hdu2063]过山车(二分图匹配)

    题意:每个女人有感兴趣的k个男人,过山车两人一组,求最大匹配数. 解题关键:二分图最大匹配.匈牙利算法求解. 1.链式前向星建图 #include<cstdio> #include< ...

  6. 《Java多线程编程核心技术》读后感(十二)

    类ThreadLocal的使用 主要解决的是每个线程绑定自己的值,可以将ThreadLocal类比喻成全局存放数据的盒子,盒子中可以存储每个线程私有数据. 类ThreadLocal解决的是变量在不同线 ...

  7. 通过xpath获取对应的整个子节点信息

    1.页面解析接口 package com.dajiangtai.djt_spider.service; import com.dajiangtai.djt_spider.entity.Page; /* ...

  8. location对象介绍

    Location 对象 Location 对象 Location 对象包含有关当前 URL 的信息. Location 对象是 Window 对象的一个部分,可通过 window.location 属 ...

  9. 关于 Number() parsint() abs() 的区别

    1. parseInt(‘’)      parseInt() 函数可解析一个字符串,并返回一个整数. 如果第一个字符不是数字或者负号,parseInt() 就会返回NaN 2.Number()    ...

  10. 怎么将vim的剪切版设置成系统的剪切版

    如果你用vim敲完了代码,怎么把代码提交到ACMoj的粘贴版上呢. 这是个问题. 去网上查了一下,首先有人说可以在vimrc里面添加 set clipboard=unnamed 我试了一下,没有效果. ...