- 1、本文档共47页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
性能检测与问题调试篇
思考题1、一个系统运行的常见硬件与网络条件有哪些?答:电脑主机,网线,路由器,交换机2、评价硬件的主要参数有哪些?答:CPU线程数,内存大小,硬盘大小,硬盘读写频率性能计数器查看IISWeb请求连接数是哪个指标?答:Request.Current3、FusionLog的作用是什么?答:日志记录查看工具4、利用windbg,如何查看当前占用CPU特高的线程的最后执行堆栈?答:!dumpheap-stat5、能够应用ARR的一些场景?答:在多个服务器上部署网站,可以充分利用多个服务器资源,提高用户体验
软件纠错的六个阶段:这不可能。我机器上就没事。不应该呀。为什么会出现这种问题?噢,我明白了。以前怎么就没问题软件Bug,业界一件很常见的现象
千行代码缺陷率(bug率)CMM1级??11.95‰CMM2级???5.52‰CMM3级???2.39‰CMM4级??0.92‰CMM5级??0.32‰Raytheon公司的BUG率为0.03‰如果我们一味的强调软件必然有BUG,那可能打到朝鲜的导弹会直接偏离到日本,虽然这些确实跟人员的素质、生产率的质量以及管理有很大的关系,我们可以不用这种标准来要求自己,但要向着好的目标前进。至少要意识到,提高软件质量,降低缺陷率,达到一个高度,在业内是存在的,只是我们的环境和客观条件让我们停滞不前
AEDBC出现超出Limit链接数整体页面响应慢间歇性出现重新登录页面无任何响应频繁出现错误裁判文书网问题描述
1性能对Bug的影响2性能不足,导致运算超时,原代码未进行合理判断,会导致异常3性能不足,导致资源加锁,出现并发共享错误4性能不足,导致内存溢出6性能不足,导致Web前端事件出现紊乱5性能不足,导致不能响应请求性能篇
01CPU资源02内存资源03网络资源04IO资源05硬盘资源资源使用情况性能的基础:环境
基本网络拓扑结构公众防火墙路由器交换机存储服务器台式机笔记本内部用户
系统基本环境
系统使用情况核数内存可用数CPU占用
大型服务器的截图
单核计算满负荷,现象为总CPU使用接近1/N,图中为1/4。
现象:全部满负荷,现象为总CPU使用接近100%。问题:当长期满负荷CPU时,这时程序一定存在问题,需要进行排查,对文档的。服务器的CPU利用率在50-60%则是一个较高的利用水平原因:高密度的计算性逻辑例如:大循环,死循环特别常见的有while(true)的逻辑中
性能计数器打开方式性能计数器的快速定义外部程序监听性能计数器性能计数器
性能计数器的打开
性能计数器:定义
观察系统健康状态
性能计数器快速定义010203040506OBJECTID=DISystemMonitor1WIDTH=100%HEIGHT=100%CLASSID=CLSID:C4D2D8E0-D1DD-11CE-940F-008029004347PARAMNAME=_VersionVALUE=458755/PARAMNAME=_ExtentXVALUE=21087/PARAMNAME=Selected:%sVALUE=\ASP.NET\RequestsQueued//OBJECT
代码记录计数器PerformanceCountercpu=newPerformanceCounter(Memory,AvailableMBytes,);while(true){ //系统可用内存 stringavailval=string.Format({0}MB,cpu.NextValue()); //入库 Thread.Sleep(1000);}
performanceCounter1?=?new?System.Diagnostics.PerformanceCounter();?
????performanceCounter1.CategoryName?=?“Processor”;?
????performanceCounter1.CounterName?=?“%?Processor?Time”;?
????performanceCounter1.InstanceName?=?“_Total”;?
????performanceCounter1.MachineName?=?SER_IP?;//此处可以为其他服务器的地址,其他机器需要开启Remote?Registry服务Example:https://Windows模拟登陆
时钟01用户权限02防火墙开启状态03资源使用情况Windows基础环境
02用户权限其他常见的环境问题03防火墙开启状态01时钟
指定外部时间源并与之同步w32tm/config/manualpeerlist:/syncfrom
文档评论(0)