当我提起这件事时,我的IT人员只是耸耸肩膀,所以我转向SE寻求帮助.

我认为这张图片最好.

很简单,随着时间的推移,响应时间变得越来越糟,直到午夜某个时候发生了一些事情并且它几乎恢复到正常状态.我们在IIS上,这个页面恰好仍然在Classic ASP中,但这种情况发生在所有页面上,甚至是普通的HTML页面,我认为它排除了sql连接问题.

我想我的问题是,我从哪里开始寻找?我经历了常规日志,没有看到任何跳出来的东西.但事情显然正在发生,我不知道从哪里开始.

有许多事情可能导致这种情况 – 不幸的是,我们可能需要更多信息.

在我进入实际响应之前,只需在HTML页面上快速查看一下:一般来说,应用程序池一次只能响应一定数量的请求.如果它忙于响应对动态页面的请求,那么它可能没有任何线程来为静态页面提供服务.出于这个原因,动态页面上的代码问题可能会产生静态页面“缓慢”服务的错觉.我的观点是,不排除代码或sql.

例如:如果您有100个页面同时点击数据库或API,并且所有100个页面都在等待响应,则可能会阻止请求101直到前100个中的1个完成.

现在,您可以做很多事情来帮助您诊断此问题:

>您的负载情况通常如何?这会产生很大的不同 – 可能是您总是遇到问题,但在您的网站实际收到负载之前,您无法看到影响.您可以尝试使用JMeter之类的东西测试它(在分段中).
>启用IIS日志(如果尚未启用),然后查看它们以查看哪些请求的时间最长.您可以使用Log Parser(来自Microsoft)之类的东西来对您的日志运行类似sql的查询(甚至将日志转储到sql数据库中),如果这样可以让生活更轻松.一旦您知道哪些页面花费的时间最长,您就可以将注意力集中在它们上.
>您的应用程序是否有日志?如果没有,您应该考虑添加一些日志记录.如果您已有日志,他们会说什么?您的应用程序是否会抛出异常?有什么东西一直都在失败吗?
>您的应用程序池使用了多少内存?内存泄漏是一个明显的候选者,但你应该很容易看到.使用Windows内置的性能监视器来跟踪当天应用程序池消耗的内存,并查看它是否随着日期的增加而增加.
>正如我在开头提到的,sql可能仍然是一个问题.我建议看看数据库服务器,看看是否存在任何长时间运行或被阻止的查询(例如,在sys.dm_exec_requests中,查看wait_type,wait_time,blocking_session_id和total_elapsed_time).
>使用TCPView(另一个Microsoft工具)之类的内容检查应用程序池已打开的连接数.您的应用程序池将尝试尽可能重用连接,但您可能会看到许多与应用程序池的打开连接.您可以从中看到一个有趣的事情,现在您已经打开了许多与sql数据库或应用程序使用的外部API的连接.
>使用应用程序性能和监视工具. AppDynamics或类似工具将能够帮助查明代码执行速度慢的部分.不幸的是,有一点学习曲线可以有效地使用这些工具,但它们在帮助诊断应用程序问题方面非常强大.

更新

如果您有内存泄漏,重新启动应用程序池可能有助于解决问题,但您需要小心:可能会有一些不利影响.重新启动应用程序池后,应用程序将开始将静态对象加载到内存等.根据应用程序的复杂程度,这可能需要很长时间(可能需要5-10分钟或更长时间).在此期间,对服务器的请求可能会延迟,从而使问题显得更加严重.

如果您运行的是单个服务器,则在应用程序重新启动时,您的站点可能会暂时不可用(由于应用程序池正忙,无法响应请求).如果您在具有负载平衡器的服务器场中运行,则负载均衡器可能会在应用程序池重新启动时丢弃您的服务器,这可能会将所有流量定向到其他服务器并使其超载.不要同时在所有服务器上重新启动应用程序池,并在将服务器重新引入服务器场之前尝试“预热”应用程序池(通过模拟对服务器的请求).

换句话说:除非它肯定是内存泄漏的问题,否则可能不值得重新启动应用程序池,因为问题可能会立即重新出现.

注意:重新启动应用程序池不会影响当前正在运行的任何请求.这些将继续完成,除非您强行关闭应用程序池(例如Crtl Alt Del)

windows-server-2008 – 随着时间的推移,响应时间会变慢,从何处开始排除故障?的更多相关文章

  1. ios – 为什么重复创建和删除SKShapeNode和SKNode导致内存泄漏?

    使用Xcode附带的spritekit模板,我修改场景如下:该应用程序似乎继续使用更多内存,直到它挂起或崩溃.使用泄漏和分配工具,我发现了以下内容:泄漏:分配:从图像中可以看出,存在大量使用内存的Malloc调用.我不直接调用Malloc–似乎这些调用是由SpriteKit完成的.同样,存在许多内存泄漏,这似乎也是由于SKShapeNode,SKNode或其他SpriteKit对象造成的.我如何解决或解决此内存(泄漏)问题?

  2. ios – Xcode显示内存泄漏,但仪器没有

    当我从Xcode运行我的应用程序时,很明显我有一个内存泄漏:当我提供一个自定义的ViewController时,内存增加,但是当我关闭它时,它不会退回.所以我也检查了使用仪器的分配工具,但这说明了一个不同的故事:可以看出,当我呈现ViewController时,仪器会显示尖峰,但是当内存使用被关闭时,内存使用率将恢复到以前的级别.我已经检查了我的代码至少15次,我个人无法找到任何内存泄漏,因此同意

  3. ios – 内存泄漏与UIWebView和Javascript

    清楚地包含一个Javascript文件到我的HTML是使UIWebView泄漏内存.当我重复使用相同的UIWebView对象时,或者每当我有内容实例化一个新的漏洞时,会出现泄漏的事实,导致我认为必须有一些JavaScript文件被loadHTMLString处理,导致泄漏.有人知道如何解决这个问题吗?

  4. ios – SBJson – 有内存泄漏?

    我刚刚克隆了SBJson框架的git存储库,并将源代码导入到我的应用程序中.跑了一个静态内存探查器,并从我看到的结果有点害怕.看图这怎么可能?我怀疑这个知名图书馆的开发者没有看到这个?事实上,如果运行内存配置文件,它会显示此库中的内存泄漏.有任何想法吗?

  5. 14.6 Swift中weak解决循环强引用

    /**循环强引用ARC不是万能的,它可以很好的解决内存过早释放的问题,但是在某些场合下不能很好的解决内存泄漏的问题。直接用官方例子*/classPerson{letname:Stringinit{self.name=name}varapartment:Apartment?这就是所谓的循环强引用*///这是强引用,不要认为可选类型就是弱引用啊,只有通过weakuNowned才是弱引用varjohn:Person?*//**在变量tenant前加上weak修饰,也就是将其中的一个变量设置为弱引用就行了。joh

  6. Swift闭包中的内存泄漏

    内存泄漏不仅破坏用户体验,而且会影响性能甚至应用的安全。既然内存泄漏如此的重要,所以这篇文章在这篇文章将说一说Swift闭包中的内存泄漏问题。Apple在文章中详细介绍了循环强引用的概念、何为内存泄漏、如何避免。内存泄漏的调试上面我们分析了大部分闭包中的循环引用问题,我们得知并不是所有的情况下都会导致内存泄漏。

  7. Android – 从低内存条件恢复

    我正在开发一个非常强烈的图像处理应用程序,我在水平FragmentStatePagerAdapter中有多个ListFragments.我积极地采用几乎每一个窍门和建议,我能够在这里和其他地方找到.我下载位图并将其保存到SD和软参考存储器缓存.然而,当我在某些时候使用该应用程序,我开始在LogCat中看到消息,就像下面一样如果我继续,上面的消息将变得更加迫切并且不可避免的应用程序将与OutOfMe

  8. Android内存泄漏的原因及解决技巧

    这篇文章主要介绍了Android内存泄漏的原因及解决技巧,帮助大家更好的利用Android进行开发,感兴趣的朋友可以了解下

  9. nodeJs内存泄漏问题详解

    由于内存泄漏在Node.js中非常的常见,可能在浏览器中应用javascript时,对于其内存泄漏不是特别敏感,但作为服务器语言运行时,你就不得不去考虑这些问题。

  10. vue中的eventBus会不会产生内存泄漏你知道吗

    这篇文章主要为大家详细介绍了vue中的eventBus会不会产生内存泄漏,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下,希望能够给你带来帮助

随机推荐

  1. static – 在页面之间共享数据的最佳实践

    我想知道在UWP的页面之间发送像’selectedItem’等变量的最佳做法是什么?创建一个每个页面都知道的静态全局变量类是一个好主意吗?

  2. .net – 为Windows窗体控件提供百分比宽度/高度

    WindowsForm开发的新手,但在Web开发方面经验丰富.有没有办法为Windows窗体控件指定百分比宽度/高度,以便在用户调整窗口大小时扩展/缩小?当窗口调整大小时,可以编写代码来改变控件的宽度/高度,但我希望有更好的方法,比如在HTML/CSS中.在那儿?

  3. 使用Windows Azure查询表存储数据

    我需要使用特定帐户吗?>将应用程序部署到Azure服务后,如何查询数据?GoogleAppEngine有一个数据查看器/查询工具,Azure有类似的东西吗?>您可以看到的sqlExpressintance仅在开发结构中,并且一旦您表示没有等效,所以请小心使用它.>您可以尝试使用Linqpad查询表格.看看JamieThomson的thispost.

  4. windows – SetupDiGetClassDevs是否与文档中的设备实例ID一起使用?

    有没有更好的方法可以使用DBT_DEVICEARRIVAL事件中的数据获取设备的更多信息?您似乎必须指定DIGCF_ALLCLASSES标志以查找与给定设备实例ID匹配的所有类,或者指定ClassGuid并使用DIGCF_DEFAULT标志.这对我有用:带输出:

  5. Windows Live ID是OpenID提供商吗?

    不,WindowsLiveID不是OpenID提供商.他们使用专有协议.自从他们的“测试版”期结束以来,他们从未宣布计划继续它.

  6. 如果我在代码中进行了更改,是否需要重新安装Windows服务?

    我写了一个Windows服务并安装它.现在我对代码进行了一些更改并重新构建了解决方案.我还应该重新安装服务吗?不,只需停止它,替换文件,然后重新启动它.

  7. 带有双引号的字符串回显使用Windows批处理输出文件

    我正在尝试使用Windows批处理文件重写配置文件.我循环遍历文件的行并查找我想要用指定的新行替换的行.我有一个’函数’将行写入文件问题是%Text%是一个嵌入双引号的字符串.然后失败了.可能还有其他角色也会导致失败.如何才能使用配置文件中的所有文本?尝试将所有“在文本中替换为^”.^是转义字符,因此“将被视为常规字符你可以尝试以下方法:其他可能导致错误的字符是:

  8. .net – 将控制台应用程序转换为服务?

    我正在寻找不同的优势/劣势,将我们长期使用的控制台应用程序转换为Windows服务.我们为ActiveMQ使用了一个叫做java服务包装器的东西,我相信人们告诉我你可以用它包装任何东西.这并不是说你应该用它包装任何东西;我们遇到了这个问题.控制台应用程序是一个.NET控制台应用程序,默认情况下会将大量信息记录到控制台,尽管这是可配置的.任何推荐?我们应该在VisualStudio中将其重建为服务吗?我使用“-install”/“-uninstall”开关执行此操作.例如,seehere.

  9. windows – 捕获外部程序的STDOUT和STDERR *同时*它正在执行(Ruby)

    哦,我在Windows上:-(实际上,它比我想象的要简单,这看起来很完美:…是的,它适用于Windows!

  10. windows – 当我试图批量打印变量时,为什么我得到“Echo is on”

    我想要执行一个简单的批处理文件脚本:当我在XP中运行时,它给了我预期的输出,但是当我在Vista或Windows7中运行它时,我在尝试打印值时得到“EchoisOn”.以下是程序的输出:摆脱集合表达式中的空格.等号(=)的两侧可以并且应该没有空格BTW:我通常在@echo关闭的情况下启动所有批处理文件,并以@echo结束它们,所以我可以避免将代码与批处理文件的输出混合.它只是使您的批处理文件输出更好,更清洁.

返回
顶部