草庐IT

java - 以编程方式检测内存泄漏

coder 2024-03-19 原文

如果我故意创建一个处理数据的应用程序,同时遭受内存泄漏,我会注意到报告的内存,比如:

Runtime.getRuntime().freeMemory()

开始在 1 到 2 MB 的可用内存之间波动。

然后应用程序进入这样一个循环:GC,处理一些数据,GC,等等。但是因为 GC 发生得如此频繁,应用程序基本上不再做其他事情了。甚至 GUI 也需要很长时间才能做出响应(而且,不,我在这里不是在谈论 EDT 问题,这实际上是 VM 基本上陷入了某种无休止的 GC 模式)。

我想知道:有没有办法以编程方式检测 JVM 不再有足够的内存?

请注意,我不是在谈论 ouf-of-memory 错误,也不是在检测内存泄漏本身。

我说的是检测应用程序运行时内存太低,以至于它基本上一直在调用 GC,几乎没有时间做其他事情(在我假设的例子中:处理数据)。

例如,重复读取在一分钟内有多少内存可用,然后查看该数字是否一直在低于不同值(例如 4 MB)之间“振荡”,是否可以得出结论:是否存在泄漏,应用程序已无法使用?

最佳答案

And I was wondering: is there a way to programmatically detect that the JVM doesn't have enough memory anymore?

我不这么认为。您可以大致了解在任何给定时刻有多少堆内存可用,但据我所知,您无法可靠地确定何时内存不足。 (当然,你可以做一些事情,比如抓取 GC 日志文件,或者尝试在空闲内存振荡中挑选模式。但这些在 JVM 变化面前可能是不可靠和脆弱的。)

但是,还有另一种(IMO 更好的)方法。

在 Hotspot 的最新版本中(我相信是 1.6 版及更高版本),您可以调整 JVM/GC,以便它更快地放弃并抛出 OOME。具体来说,JVM 可以配置为检查:

  • 在完整 GC 之后,空闲堆与总堆的比率大于给定阈值,和/或
  • 运行 GC 所花费的时间少于总时间的特定百分比。

相关的 JVM 参数是“UseGCOverheadLimit”、“GCTimeLimit”和“GCHeapFreeLimit”。不幸的是,Hotspot 的调整参数在公共(public)网络上没有很好的记录,但这些都列出了 here .

假设您希望您的应用程序做一些明智的事情……当它没有足够的内存来正常运行时就放弃……然后只需启动具有比“GCTimeLimitor”或“GCHeapFreeLimit”更小的默认值。

编辑

我发现 MemoryPoolMXBean API允许您查看单个内存池(堆)的峰值使用情况,并设置阈值。然而,我从来没有尝试过这个,并且 API 有很多提示表明并非所有 JVM 都实现了完整的 API。因此,我仍然会推荐 HotSpot 调整选项方法(见上文)而不是这个方法。

关于java - 以编程方式检测内存泄漏,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/4272541/

有关java - 以编程方式检测内存泄漏的更多相关文章

  1. ruby-on-rails - Ruby net/ldap 模块中的内存泄漏 - 2

    作为我的Rails应用程序的一部分,我编写了一个小导入程序,它从我们的LDAP系统中吸取数据并将其塞入一个用户表中。不幸的是,与LDAP相关的代码在遍历我们的32K用户时泄漏了大量内存,我一直无法弄清楚如何解决这个问题。这个问题似乎在某种程度上与LDAP库有关,因为当我删除对LDAP内容的调用时,内存使用情况会很好地稳定下来。此外,不断增加的对象是Net::BER::BerIdentifiedString和Net::BER::BerIdentifiedArray,它们都是LDAP库的一部分。当我运行导入时,内存使用量最终达到超过1GB的峰值。如果问题存在,我需要找到一些方法来更正我的代

  2. ruby - 如何以所有可能的方式将字符串拆分为长度最多为 3 的连续子字符串? - 2

    我试图获取一个长度在1到10之间的字符串,并输出将字符串分解为大小为1、2或3的连续子字符串的所有可能方式。例如:输入:123456将整数分割成单个字符,然后继续查找组合。该代码将返回以下所有数组。[1,2,3,4,5,6][12,3,4,5,6][1,23,4,5,6][1,2,34,5,6][1,2,3,45,6][1,2,3,4,56][12,34,5,6][12,3,45,6][12,3,4,56][1,23,45,6][1,2,34,56][1,23,4,56][12,34,56][123,4,5,6][1,234,5,6][1,2,345,6][1,2,3,456][123

  3. ruby - 解析 RDFa、微数据等的最佳方式是什么,使用统一的模式/词汇(例如 schema.org)存储和显示信息 - 2

    我主要使用Ruby来执行此操作,但到目前为止我的攻击计划如下:使用gemsrdf、rdf-rdfa和rdf-microdata或mida来解析给定任何URI的数据。我认为最好映射到像schema.org这样的统一模式,例如使用这个yaml文件,它试图描述数据词汇表和opengraph到schema.org之间的转换:#SchemaXtoschema.orgconversion#data-vocabularyDV:name:namestreet-address:streetAddressregion:addressRegionlocality:addressLocalityphoto:i

  4. java - 等价于 Java 中的 Ruby Hash - 2

    我真的很习惯使用Ruby编写以下代码:my_hash={}my_hash['test']=1Java中对应的数据结构是什么? 最佳答案 HashMapmap=newHashMap();map.put("test",1);我假设? 关于java-等价于Java中的RubyHash,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/22737685/

  5. ruby - RuntimeError(自动加载常量 Apps 多线程时检测到循环依赖 - 2

    我收到这个错误:RuntimeError(自动加载常量Apps时检测到循环依赖当我使用多线程时。下面是我的代码。为什么会这样?我尝试多线程的原因是因为我正在编写一个HTML抓取应用程序。对Nokogiri::HTML(open())的调用是一个同步阻塞调用,需要1秒才能返回,我有100,000多个页面要访问,所以我试图运行多个线程来解决这个问题。有更好的方法吗?classToolsController0)app.website=array.join(',')putsapp.websiteelseapp.website="NONE"endapp.saveapps=Apps.order("

  6. ruby-on-rails - Ruby 中的内存模型 - 2

    ruby如何管理内存。例如:如果我们在执行过程中采用C程序,则以下是内存模型。类似于这个ruby如何处理内存。C:__________________|||stack|||------------------||||------------------|||||Heap|||||__________________|||data|__________________|text|__________________Ruby:? 最佳答案 Ruby中没有“内存”这样的东西。Class#allocate分配一个对象并返回该对象。这就是程序

  7. ruby-on-rails - 正确的 Rails 2.1 做事方式 - 2

    question的一些答案关于redirect_to让我想到了其他一些问题。基本上,我正在使用Rails2.1编写博客应用程序。我一直在尝试自己完成大部分工作(因为我对Rails有所了解),但在需要时会引用Internet上的教程和引用资料。我设法让一个简单的博客正常运行,然后我尝试添加评论。靠我自己,我设法让它进入了可以从script/console添加评论的阶段,但我无法让表单正常工作。我遵循的其中一个教程建议在帖子Controller中创建一个“评论”操作,以添加评论。我的问题是:这是“标准”方式吗?我的另一个问题的答案之一似乎暗示应该有一个CommentsController参

  8. ruby - 寻找通过阅读代码确定编程语言的ruby gem? - 2

    几个月前,我读了一篇关于ruby​​gem的博客文章,它可以通过阅读代码本身来确定编程语言。对于我的生活,我不记得博客或gem的名称。谷歌搜索“ruby编程语言猜测”及其变体也无济于事。有人碰巧知道相关gem的名称吗? 最佳答案 是这个吗:http://github.com/chrislo/sourceclassifier/tree/master 关于ruby-寻找通过阅读代码确定编程语言的rubygem?,我们在StackOverflow上找到一个类似的问题:

  9. java - 从 JRuby 调用 Java 类的问题 - 2

    我正在尝试使用boilerpipe来自JRuby。我看过guide从JRuby调用Java,并成功地将它与另一个Java包一起使用,但无法弄清楚为什么同样的东西不能用于boilerpipe。我正在尝试基本上从JRuby中执行与此Java等效的操作:URLurl=newURL("http://www.example.com/some-location/index.html");Stringtext=ArticleExtractor.INSTANCE.getText(url);在JRuby中试过这个:require'java'url=java.net.URL.new("http://www

  10. java - 我的模型类或其他类中应该有逻辑吗 - 2

    我只想对我一直在思考的这个问题有其他意见,例如我有classuser_controller和classuserclassUserattr_accessor:name,:usernameendclassUserController//dosomethingaboutanythingaboutusersend问题是我的User类中是否应该有逻辑user=User.newuser.do_something(user1)oritshouldbeuser_controller=UserController.newuser_controller.do_something(user1,user2)我

随机推荐