第十九章 排查和调试Web程序 之 防止和排查运行时问题
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程序 之 防止和排查运行时问题的更多相关文章
- 第二十章 排查和调试Web程序 之 设计异常处理策略
1. 概述 本章内容包括: 多层架构中的异常处理.使用global.asax 或 自定义的HttpHandler 或 web.config中的属性来显示特定的错误页.处理 first chance 异 ...
- 第十九章——使用资源调控器管理资源(1)——使用SQLServer Management Studio 配置资源调控器
原文:第十九章--使用资源调控器管理资源(1)--使用SQLServer Management Studio 配置资源调控器 本系列包含: 1. 使用SQLServer Management Stud ...
- Gradle 1.12翻译——第十九章. Gradle 守护进程
有关其他已翻译的章节请关注Github上的项目:https://github.com/msdx/gradledoc/tree/1.12,或访问:http://gradledoc.qiniudn.com ...
- 20190908 On Java8 第十九章 类型信息
第十九章 类型信息 RTTI(RunTime Type Information,运行时类型信息)能够在程序运行时发现和使用类型信息. Java 主要有两种方式在运行时识别对象和类信息: "传 ...
- Python之路【第十九章】:Django进阶
Django路由规则 1.基于正则的URL 在templates目录下创建index.html.detail.html文件 <!DOCTYPE html> <html lang=&q ...
- 第十九章——使用资源调控器管理资源(2)——使用T-SQL配置资源调控器
原文:第十九章--使用资源调控器管理资源(2)--使用T-SQL配置资源调控器 前言: 在前一章已经演示了如何使用SSMS来配置资源调控器.但是作为DBA,总有需要写脚本的时候,因为它可以重用及扩展. ...
- 第十九章 Django的ORM映射机制
第十九章 Django的ORM映射机制 第一课 Django获取多个数据以及文件上传 1.获取多选的结果(checkbox,select/option)时: req.POST.getlist('fav ...
- Gradle 1.12用户指南翻译——第四十九章. Build Dashboard 插件
本文由CSDN博客貌似掉线翻译,其他章节的翻译请参见: http://blog.csdn.net/column/details/gradle-translation.html 翻译项目请关注Githu ...
- Gradle 1.12用户指南翻译——第二十九章. Checkstyle 插件
其他章节的翻译请参见: http://blog.csdn.net/column/details/gradle-translation.html 翻译项目请关注Github上的地址: https://g ...
随机推荐
- Mysql 5.7.18忘记密码
5.7.18密码修改发生了变化,旧版的方法不再奏效. 1. ps -ef | grep mysqld,kill掉启动的mysql服务: 2. 创建/etc/my.cnf,添加: [mysqld] sk ...
- Jenkins持续集成环境搭建
1部署Jenkins Jenkins部署很简单,只需建立一个新应用,将Jenkins的war包部署进去,再分配好权限就可以了. 1.1创建应用 建立一个新Nginx应用:jenkins.com 1.2 ...
- PHP调用Python快速发送高并发邮件
1 简介 在PHP中发送邮件,通常都是封装一个php的smtp邮件类来发送邮件.但是PHP底层的socket编程相对于Python来说效率是非常低的.CleverCode同时写过用python写的爬虫 ...
- cassandra自启动服务器脚本
新建一个文件. vi /etc/rc.d/init.d/vi cassandra2 #!/bin/sh # chkconfig: # description: service -- # process ...
- maven学习九 关于maven一些參數
一 maven profile: 不同的运行环境,比如开发环境.测试环境.生产环境,而我们的软件在不同的环境中,有的配置可能会不一样,比如数据源配置.日志文件配置.以及一些软件运行过程中的基 ...
- bzoj4453
单调栈+set+后缀数组 一道奇妙的题 这道题如果对于每个询问$r$是固定的,那么就很简单了,可惜并不是 由于r会变化,那么对于两个子串$[i...r],[j...r]$,他们的大小关系随着r的变化也 ...
- CF-845C
C. Two TVs time limit per test 2 seconds memory limit per test 256 megabytes input standard input ou ...
- login.aspx.cs
using System; //指令+系统(命名空间)using Sys ...
- WPF后台修改内容界面不显示问题
通知3部曲:1.Model继承并实现 INotifyPropertyChanged 接口:2.数据集合使用ObservableCollection<T>集合:3.View使用Binding ...
- 模板 - 动态规划 - 区间dp
因为昨天在Codeforces上设计的区间dp错了(错过了上紫的机会),觉得很难受.看看学长好像也有学,就不用看别的神犇的了. 区间dp处理环的时候可以把序列延长一倍. 下面是 $O(n^3)$ 的朴 ...