[翻译]编写高性能 .NET 代码 第一章:性能测试与工具 -- 选择什么来衡量

选择什么来衡量

在搜集数据测试数据前,你需要知道你要以怎样的指标来衡量测试结果。这听起来很容易,但实际上比你想象中的要难许多。如果你想降低内存使用量,你会选择什么方式呢?

  • 私有工作集(Private working set)

  • 提交大小(Commit size)

  • 内存页(Paged pool)

  • 峰值大小(Peak working set)

  • 内存堆大小(.NET heap size)

  • 大对象堆(Large object heap)
    and so on

为了追踪内存的使用情况,我们还需要记录一个小时内的平均值和峰值?内存与处理器进程负载的关系?正如你所看到的,随便就能举出十几个甚至更多与内存相关的性能指标。

我们需要尽可能的准确描述要测试的东西

一旦你决定要测试某个产品,你需要为每个性能指标提出一个目标。在早期开发阶段,订立的目标可能不够准确,或者与实际情况不符。但重点是,不是说一定要达到一开始规划的目标,而是强迫你构建一套可以自动测试你说提出这些性能指标的体系结构。
你的目标应该是可量化的吗,你的程序目标也许是“快”,这个是一个不错的指标,但不是一个好的指标,因为“快”是一个很主观的因素,你没有一个明确的东西来表示你是否达到了快这个目标。你需要给目标定一个数字,并且这个数字是要可以测试出来的。

坏:“用户界面需要正常相应”
好:“任何操作不应该造成UI线程卡住超过20毫秒”

能量化还不够好,还需要有更具体的描述,例如下面说的内存指标

坏:“内存应小于1G”
好:“内存在 100次/秒的峰值查询情况下,内存使用不超过1G”

对于第二个例子,给出了一个具体的情景,要在这个情景下达成怎样的目标就是一个比较好的测试用例

另外一个重要的决定性因素,是你写的应用的目标是什么。如果是以一个带GUI界面的引用,那么你需要必须保证任何时刻都能响应用户的操作请求。如果你写的是一个每秒处理几百几千访问的服务器程序,你的目标就算要保证I/O和CPU的利用率在一个很低的范围内。如果你设计的是一个与市面上不一样的服务器应用,那么从效率的角度上看,一旦你的架构除出问题(性能上的),在重新修改架构就非常麻烦了。

在设计新系统时,我们需要对性能指标做一些规划。这时你需要了解一些会对性能产生影响的地方,例如CPU,内存,IO的使用率等情况。举个栗子,如果你有一台16核,64G内存的机器以及10G的网络带宽,这时候你需要设定好一个阈值,如“每秒可以处理多少数据”,这个可以在一台机器无法满足需要时,你知道你还需要多少台机器。这些信息都是你在做规划时需要写在规划目标里的。

你可能听过 _Donald Knuth 说过的:“过早优化是万恶之源”。但这只适合代码级别的优化。你必须清楚你在设计上的缺陷会对应用产生多大的影响。你必须把性能目标考虑到设计中。你必须在一开始时就有一个明确的目标。性能和安全以及一些东西时不能事后设计,否则你会被架构重构教会你做人的道理。

性能分析(设计)放在项目的开始,比在写完代码后进入测试阶段再考虑性能,思路是不一样的。在项目开始前,你可以设计出达到你想要的在性能上的扩展性,而不会陷入一些架构陷阱里(我暂时没明白这里说的架构陷阱是指那些东西)。在进入项目的测试,部署和维护阶段,你才有更多的时间在代码层级的优化上,对热点函数代码做分析,减少cpu,内存的消耗。

最后,你需要了解Ahmdals定律(See [pdf]:http://www.writinghighperf.net/go/3),特别是如何适用于顺序(序列化)编程以及选择哪个部分进行优化。在代码级别的优化堆整体性能用处不大,甚至会浪费时间。但你总是希望优化代码里效率最低的那部分。不过,聪明的你应该会知道,你不会有足够时间去干这件事情。这就是为什么你需要有一个好的性能监控系统(工具),否则,你甚至不知道从哪里改起。

原文地址:http://www.cnblogs.com/yahle/p/6267039.html


.NET社区新闻,深度好文,微信中搜索dotNET跨平台或扫描二维码关注

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/325352.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

RPC远程过程调用之Hessian 基于HTTP

Hessian使用C/S方式&#xff0c;基于HTTP协议传输&#xff0c;使用Hessian二进制序列化。 添加依赖&#xff1a; <dependency><groupId>com.caucho</groupId><artifactId>hessian</artifactId><version>4.0.7</version> </depen…

EF框架中,在实体中手动更新字段,数据库数据未同步到程序中应该怎么解决呢?

在一些技术不是很强的选手手中&#xff0c;设计数据库时&#xff0c;难免会未考虑到某些字段&#xff0c;只能到后期实现功能时&#xff0c;才能觉察出来数据库中或是少写字段&#xff0c;或是多加了无用的字段&#xff0c;故我们还不得不去数据库中做些手脚。 本文列举的是在…

[.NET跨平台]Jexus独立版本的便利与过程中的一些坑

本文环境与前言 之前写过一篇相关的文章:在.NET Core之前,实现.Net跨平台之MonoCentOSJexus初体验 当时的部署还是比较繁琐的,而且需要联网下载各种东西..有兴趣的可以看看,但是..已经过时了.. 虽然已经出了.NET Core2.0 但是目前是预览版本,而且部署来说 相对比较麻烦. 今…

nacos伪集群安装注意到

1&#xff1a;端口需要隔离开 新版增加GRPC 不要挨着设置ip&#xff0c;否则会出现端口占用。 可以使用 8848 8858 8868 8848GRPC会占用9848 9899 8849&#xff1a; 占用9849 9850 8850&#xff1a; 占用9850 9851 nginx 负载也需要与上述端口 隔离开…

Comparator 和 Comparable

Comparator 和 Comparable 相同点 Comparator 和 Comparable都是java的接口&#xff0c;并且是用来对自定义的class比较大小的。 对于自定义类如&#xff1a;public class Person{ String name; int age }.   当我们有这么一个personList&#xff0c;里面包含了person1, pe…

利用JEXL实现动态表达式编译

转载自 利用JEXL实现动态表达式编译 背景 做项目突然遇到这样的需求: 系统要获取多个数据源的数据&#xff0c;并进行处理&#xff0c;最后输出多个字段。字段的计算规则一般是简单的取值最多加一点条件判断。 而且需要动态变动&#xff01;&#xff01;例如一个字段a的取值…

《四世同堂》金句摘抄(二)

System.out.println("今天读的是什么书呢&#xff1f;"); String bname "《四世同堂》"; System.out.println("今天读的书是&#xff1a;"bname);Console.WriteLine("今天读的是什么书呢&#xff1f;"); String bname "《四世同…

码农不重视文档:开源项目深受其苦

GitHub 刚刚发布了《2017 开源调查》报告&#xff0c;这家知名编程社交网站走访了 github.com 社区内 3800 多个项目和超过 5500 名成员&#xff0c;并且与 500 名在 GitHub 项目生态系统之外的编程者们进行了交谈。本次调查涉及多方面&#xff0c;比如人们在为开源项目做开发、…

kafka监控软件kafka-eagle搭建 web无法访问

https://www.likecs.com/show-204789016.html

《四世同堂》金句摘抄(三)

System.out.println("今天读的是什么书呢&#xff1f;"); String bname "《四世同堂》"; System.out.println("今天读的书还是&#xff1a;"bname);Console.WriteLine("今天读的是什么书呢&#xff1f;"); String bname "《四世…

[翻译]编写高性能 .NET 代码 第一章:性能测试与工具 -- 平均值 vs 百分比

平均值 vs 百分比 在考虑要性能测试的目标值时&#xff0c;我们需要考虑用什么统计口径。大多数人都会首选平均值&#xff0c;但在大多数情况下&#xff0c;这个正确的&#xff0c;但你也应该适当的考虑百分数。但你有可用性的要求&#xff0c;作为性能测试的目标里肯定会有用…

《四世同堂》金句摘抄(四)

System.out.println("今天读的是什么书呢&#xff1f;"); String bname "《四世同堂》"; System.out.println("今天读的书还是&#xff1a;"bname); System.out.println("在摘抄一下");下面是今天的摘抄内容 生在某一种文化中的人&a…

面对枯燥的源码,如何才能看得下去

转载自 面对枯燥的源码&#xff0c;如何才能看得下去 一个软件开发人员&#xff0c;工作到了一定的年限&#xff08;一般是3、4年左右&#xff09;&#xff0c;如果他还没学会阅读源码&#xff0c;那么他就会遇到瓶颈。因为到了这个时候的开发&#xff0c;他应该不仅仅只会做…

前端防xss攻击(去掉空格等能影响和攻击数据库的字段)

用法&#xff1a;把要传给后端的数据放到此能过滤的函数里面即可就能实现自动过滤的功能 eg 代码 export function XSSFilter(str: string) {// 过滤emoji表情str str.replace(/\uD83C[\uDF00-\uDFFF]|\uD83D[\uDC00-\uDE4F]/g, );// 过滤所有html标签str str.replace(/&l…

《四世同堂》金句摘抄(五)

System.out.println("今天读的是什么书呢&#xff1f;"); String bname "《四世同堂》"; System.out.println("今天读的书还是&#xff1a;"bname); System.out.println("在摘抄一下");他们呆呆的看着他。惊异&#xff0c;怜悯&#…

[深圳/广州]微软SQL技术沙龙分享会(MVP)

[深圳/广州] 新一期俱乐部活动报名开始&#xff0c;这次是广深地区SQL Server 技术沙龙分享会&#xff08;MVP)&#xff0c;SQL Server作为一个数据平台&#xff0c;不管是SQL Server 2017 on Linux 还是把一门开源R语言融入其最赚钱的旗舰商业数据库&#xff0c;微软已经决定&…

搜索时展示的是名字,传给后端的是id

展示普通的select框 const [typeList, setTypeList] useState(["增加","减少"]);<Form.Item name"fruitType" label"类型" rules{[{ required: true }]}><Select style{{width:500}} placeholder"请选择类型">…

IntelliJ IDEA 2018.2 发布,支持 Java 11

转载自 IntelliJ IDEA 2018.2 发布&#xff0c;支持 Java 11 近期&#xff0c;JetBrains发布了其旗舰产品IntelliJ IDEA的2018.2版本。新版本支持即将推出的Java 11、断点意图&#xff08;Breakpoints Intentions&#xff09;、MacBook的Touch Bar等特性&#xff0c;并改进了…

发布支持多线程的PowerShell模块 —— MultiThreadTaskRunner

应用场景 多线程在需要批量处理一些任务的时候相当有用&#xff0c;也更加有利于充分利用现有计算机的能力。所有主流的开发语言都支持多线程。 默认情况下&#xff0c;PowerShell作为一个脚本语言&#xff0c;是不支持多线程操作的&#xff0c;虽然有所谓的后台任务&#xf…