资源泄漏如何处理_处理缓慢的资源泄漏

资源泄漏如何处理

使用Java监视器查找资源泄漏

查找缓慢的资源泄漏是使应用程序服务器长时间保持正常运行的关键。 在这里,我解释了如何使用Java监视器来发现缓慢的资源泄漏,以及如何验证它们是否是实际泄漏,而不仅仅是额外的预分配到某些HTTP连接器或数据库池中。 如果执行这些步骤,则可以摆脱定期重新启动,并真正开始依赖服务器。

缓慢的资源泄漏是一个问题,因为它们迫使您定期重新启动应用程序服务器。 反过来,这意味着您必须始终盯着服务器,因为它们可能随时崩溃。 最终,您不能依赖遭受缓慢资源泄漏的服务器。 跟踪和解决缓慢的资源泄漏需要时间和耐心。 一旦完成几次,这并不是很难做到的。

您还需要一个监视工具,该工具可以显示过去几周甚至几个月内来自服务器的统计信息。 如果在服务器上启用了更长的数据存储,则可以使用Java监视器来执行此操作。 要在Java监视器中启用此功能,请首先开始对服务器使用Java监视器 。 在带有服务器图形的页面上,可以通过切换到“ 1周”或“ 1个月”视图来启用更长的数据,如下所示。

开关

第一步是查看过去一周中服务器的数据。 为了发现资源泄漏,我发现绘制一周的数据比查看Java监视器标准的两天的数据要好。 峰平滑了,这些图让我看看例如内存使用随时间如何发展。

为了预测即将发生的中断和缓慢的资源泄漏,我寻找两种模式。 首先要检查的模式是资源使用量不会随时间增加,而是随着流量的日趋增加和减少而增加和减少。 当一天的流量减少后,我预计资源使用量将回落到名义水平。 我检查资源使用率是否每次都回落到同一水平。

请注意,我故意使用诸如“资源”之类的模糊术语。 在实践中,我查看所有图的内存,文件描述符以及HTTP连接器和数据库连接池。 所有这些都是缓慢的资源泄漏的候选者。

当我看到资源似乎在增长的时候,我切换到数据的每月视图,甚至年度视图。 这将压缩图中的数据,并使缓慢的资源泄漏更容易发现。

这是资源使用情况可疑更改的示例。 在这种情况下,系统上的垃圾收集器突然变得更加活跃。 此时,系统或系统负载没有变化。

慢1

我要注意的第二种模式是服务器重启重启后资源分配急剧下降。 重新启动应用程序服务器时,如果资源使用量显着下降,则可能表明资源泄漏缓慢。 重新启动之后,通常会像重新启动之前那样降低资源使用量,因为所有池和缓存都开始为空。

这是一个与重启相关的资源使用变化的示例,该变化并不表示有问题。 重新启动后一段时间(甚至几天),资源使用情况发生了变化,但随后又恢复到正常水平并停留在该水平。

慢3

这是另一个。 甚至更加可疑,因为重新启动后资源使用率并未恢复。 它只是掉下来并停留下来。 这几乎肯定是一个问题。

慢5

一旦确定资源使用模式可疑,就必须确认这实际上是一个缓慢的泄漏。 很有可能是缓存或池中填充了更多缓存,从而随着时间的推移提高了资源使用率,而没有实际泄漏。 在这一步中,我将遍历线程和数据库池的图以及HTTP会话的图。 我试图从那里的图表来解释提高的资源使用情况。

例如,在这里我们看到了JVM中活动的线程,线程数量有些奇怪的下降。 这些下降表明系统重新启动。

慢2

但是,如果将该图与同一台服务器上的HTTP连接器池图进行比较,我会发现HTTP连接器池中预分配的线程数同样会上下波动。

慢4

这可能意味着没有缓慢的资源泄漏。 最有可能的是,池中的额外线程保持状态,从而导致其他资源也增加。 我可能会记下具体注意此服务器的信息,但我还没有开始深入研究资源泄漏。

只有当我无法解释从池中分配的额外资源和活动HTTP会话的数量时,我才真正开始挖掘。 如下所述: 如何找到资源泄漏缓慢的根本原因 。

解决缓慢的资源泄漏

我们研究了如何较早发现缓慢的内存泄漏。 在那里,我们看到了如何发现缓慢的资源泄漏,以及如何将其与预期的池增长行为区分开。

在这里,我想解释一下如何确定缓慢的资源泄漏的根本原因,以及最终如何解决它们。 修复缓慢的资源泄漏几乎总是需要更改代码,因此,如果您无法更改代码,则无法修复缓慢的资源泄漏。 在这种情况下,您将必须找到可以的人。

识别缓慢资源泄漏的根本原因的过程类似于发现快速泄漏的过程。 主要区别是时间对您不利。 对于快速泄漏,您可以轻松地进行几次迭代,而缓慢的泄漏则可能需要数周或数月才能显现出来。 迭代可能是一年的四分之一。 为了更快地泄漏,您可以快速更改代码并“实时查看其运行状况”。 对于较慢的泄漏,这仅意味着您将永远找不到真正的问题。

要遵循的步骤是:

  1. 确定泄漏的资源(完成,是的!)
  2. 收集有关该资源的证据
  3. 撰写关于什么是问题的论文,看看证据是否支持您
  4. 向您认识的人展示您的分析结果,从而将您的证据撕成碎片
  5. 设计并实施修复

请注意,我们通常通常只快速执行步骤3,然后将所有精力花在步骤5上,却发现真正的问题是其他问题。 我应该知道,因为我犯错的次数比我愿意承认的还要多。

一旦知道泄漏了哪些资源(例如内存,文件描述符,CPU周期,线程),便开始收集有关泄漏的证据。 该证据来自多个来源。 如果泄漏的资源仅在您的代码中很少使用,则应用程序源代码是开始收集的好地方。 如果这是在各处(例如内存)使用的东西,那么查看源代码通常很耗时,并且效率不高。 因此,这是我要寻找证据的备忘单:

  • 记忆
    --->堆转储
  • 文件描述符
    ---> Java监视器的线程池图以及lsof或sockstat
  • 中央处理器
    --->线程转储
  • 线程数
    ---> Java监视器的线程池图和线程转储
  • 数据库连接
    --->在JDBC驱动程序上启用资源泄漏检测

收集证据时,保持开放的态度非常重要。 得出关于正在发生的事情的结论是很诱人的。 相反,只需查看很酷的证据并消除可能的问题。

至关重要的一步是向不惧怕挑战您的人提供您的证据和思路。 此步骤是为了防止您在分析中犯错误,并且必须等待几周才能发现自己是错误的。 在这个阶段,只是点头和鼓掌的人可能弊大于利,不管这个人的意图多么好。 找到合适的人,并告诉该人您需要严格的审查。

一旦您的分析克服了这一挑战,您就可以最终开始考虑解决方案。 该解决方案需要包括两个部分:1)它需要以一种使系统为您提供有关刚刚发现的问题的证据的方式来改进日志记录和监视,以及2)它需要实际解决该问题。

如果您的解决方案不正确,改进的日志记录将为您提供新的新证据,以供您进行第二次(可能是最终的!)迭代。

参考: Java-Monitor博客上的JCG合作伙伴 Kees Jan Koster处理缓慢的资源泄漏。

翻译自: https://www.javacodegeeks.com/2013/09/dealing-with-slow-resource-leaks.html

资源泄漏如何处理

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

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

相关文章

mac php 超时,PHP---Mac上开启php错误提示

发现在使用mac 上 PHP开发项目的时候,程序代码错误的时候没有错误提示,只是提示白板。研究和查找资料才调整了一下; 步骤如下:1.找到php.ini文件如图所示:1)找到 display_errors Off ,把Off 改为 On . 最后为 display…

tomcat 轮询_用Spring长轮询Tomcat

tomcat 轮询就像喜剧演员弗兰基 豪威尔 ( Frankie Howerd)所说的“噢,小姐小姐” ,但足够多的英国影射和双重诱惑,因为长轮询Tomcat对隔壁的闷气不是某种性的偏见,这是一种技术(或更像是一种hac…

免费网络研讨会:Java应用程序中的吞咽异常

1月30日参加我们的网络研讨会,以发现Java应用程序中的“隐藏”异常。 如果一棵树落在森林中,但是没有写到原木上,它会发出声音吗? 答案是肯定的。 这些类型的错误可能会对用户体验造成严重影响,而没有根本原因的可见性…

Java面向对象(17)--类代码块

静态代码块:用static 修饰的代码块 ①可以有输出语句。 ②可以对类的属性、类的声明进行初始化操作。 ③不可以对非静态的属性初始化,即:不可以调用非静态的属性和方法。 ④ 静态代码块随着类的加载而加载并执行,类加载一次&…

js 和java有关系吗,javascript和JAVA有什么关系

2017-07-28Java调用javascriptpackage co。test;import java。io。FileReader;import java。io。LineNumberReader;import org。mozilla。 javascript。Context;import org。mozilla。javascript。Function;import org。mozilla。javascript。Scriptable;public class JSExplor…

php检测一个变量是否设置函数,php如何判断变量是否有设置的函数

php判断变量是否有设置的函数的方法:可以利用isset()函数来进行判断。isset()函数用于检测变量是否已设置并且非NULL。如果指定变量存在且不为NULL,则返回TRUE,否则返回FALSE。isset() 函数用于检测变量是否已设置并且非 NULL。(推荐教程&…

mockito_吸收Mockito的流利度

mockito我最近发现自己编写了一些代码来集成两个不同的平台。 这些系统之一是基于Java的系统,而另一个虽然不是用Java编写的,却提供了Java API。 我将这些系统分别称为Foo和Bar。 在我编写一行代码之前就很明显了,但是,测试最终…

Java异常处理(1)--异常概述与异常体系结构

在Java语言中,将程序执行中发生的不正常情况称为“异常”。(开发过程中的语法错误和逻辑错误不是异常) Java程序在执行过程中所发生的异常事件可分为两类: ①Error:Java虚拟机无法解决的严重问题。如:JVM系统内部错误、资源耗尽等…

Payara Micro在Oracle应用容器云上

在此博客文章中,我将介绍如何将打包在Payara Microber -jar中的CloudEE Duke应用程序部署到Oracle Application Container Cloud 。 在Oracle Application Container Cloud中进行部署所需的部署工件是一个ZIP归档文件,其中包含应用程序ber-jar和清单文件…

Java异常处理(2)--异常处理机制及自定义异常

在编写程序时,经常要在可能出现错误的地方加上检测的代码,如进行x/y运算时,要检测分母为0,数据为空,输入的不是数据而是字符等。过多的if-else分支会导致程序的代码加长、臃肿,可读性差。因此采用异常处理机…

jaas_受JAAS保护的JAX-RS端点

jaas随着RESTFUL(JAX-RS)作为创建Web服务端点的“首选”方式的问世,很长一段时间以来,我一直想知道人们如何围绕它实现安全机制。 归根结底,我假设JAX-RS的基础实现是servlet,因此其安全性也可能围绕容器&…

Java多线程(1)--基本概念:程序、进程、线程

程序(program)是为完成特定任务、用某种语言编写的一组指令的集合。即指一段静态的代码,静态对象。 进程(process)是程序的一次执行过程,或是正在运行的一个程序,是一个动态的过程:有它自身的产生、存在和消亡的过程。——生命周…

Java中的Volatile如何工作? Java中的volatile关键字示例

如何在Java中使用Volatile关键字 在Java采访中,什么是volatile变量以及何时在Java中使用volatile变量是Java 采访中一个著名的多线程采访问题 。 尽管许多程序员都知道什么是volatile变量,但是他们在第二部分上失败了,即在Java中何处使用vol…

Java线程的调度及线程的优先级

调度策略 Java的调度方法 同优先级线程组成先进先出队列(先到先服务),使用时间片策略。 对高优先级,使用优先调度的抢占式策略。 线程的优先级等级 Thread.MAX_PRIORITY:10 Thread.MIN _PRIORITY:1 Threa…

Spring Boot 2应用程序和OAuth 2 –传统方法

这篇文章是3个系列文章中的第二部分,探讨了如何为基于Spring Boot 2的应用程序启用OSO2提供程序SSO。 3个帖子是: 1. 引导兼容OpenID Connect的OAuth2授权服务器/ OpenID提供程序的方法 2.与OAuth2授权服务器/ OpenID提供程序集成的旧版Spring Boot / …

Java多线程(2)--Thread类继承和Runnable接口创建线程

Java语言的JVM允许程序运行多个线程,它通过java.lang.Thread类来体现。 Thread类的特性 每个线程都是通过某个特定Thread对象的run()方法来完成操作的,经常把run()方法的主体称为线程体,通过该Thread对象的start()方法来启动这个线程&#x…

matlab在电磁场与电磁波中的应用,matlab在电磁场与电磁波学习中的应用.docx

matlab在电磁场与电磁波学习中的应用.docx MATLAB在电磁场与电磁波学习中的应用裴逸菲(燕京理工学院信息科学与技术学院,河北廊坊065201)摘要针对电磁场与电磁波在大学课程中的理论性强、概念抽象的特点,在学习中引入MATLAB软件,利用MATLAB的…

Java多线程(3)--线程的生命周期

JDK中用Thread.State类定义了线程的五种状态 要想实现多线程,必须在主线程中创建新的线程对象。Java语言使用Thread类及其子类的对象来表示线程,在它的一个完整的生命周期中通常要经历如下的五种状态: ①新建: 当一个Thread类或…

m序列自相关matlab代码,m序列的输出及其自相关序列

【例10-2】 设m序列的生成多项式为g(x)1x^3x^4,求:(1)m序列的输出及其自相关序列;(2)脉冲波形成为矩形脉冲p(t){1 0≤t≤Tc 画出m序列信号的自相关函数;{0 其它 ,(3)设脉冲波形为升余弦函数(滚降系数a0),画…

JDK 10:从Java访问Java应用程序的进程ID

StackOverflow.com上一个普遍的问题是:“ Java程序如何获得自己的进程ID? 与该问题相关的几个答案包括解析ManagementFactory返回的String 。 getRuntimeMXBean() 。 getName() [但是可以提供“任意字符串”…