草庐IT

java - 在 Java VisualVM 中看不到我自己的应用程序方法

coder 2023-05-19 原文

我正在尝试分析我的 java 应用程序,只是为了找出花费最多时间的方法。鉴于这里对 TPTP 的 react 不佳,我想我应该试试 Java VisualVM。

这一切似乎都相当简单易用 - 除了我似乎无法从中获得任何一致或有用的东西。

我似乎看不到任何与 MY OWN 代码相关的内容 - 我得到的只是一大堆对 java.* 方法之类的调用。

我尝试将检测仅限于我自己的包,这似乎减少了检测方法的数量,但我似乎仍然没有看到我自己的。

每次运行时,我都会检测到不同数量的方法,从 10 到 1000 不等。 我已经尝试在我的应用程序启动时进入休眠状态,以确保在我的应用程序开始执行任何有趣的事情之前启动并运行 VisualVM,以确保它在有趣的东西运行时进行分析。

我必须做些什么来确保我的类(class)得到仪表化吗? 有时间问题吗? ..like,必须等待类加载等? 我还尝试过两次运行代码的核心,以确保所有代码都得到执行...

我只是在 Eclipse 中运行一个带有 main 的应用程序。我尝试使用 Eclipse 集成,以便在我启动应用程序时启动 VisualVM - 结果是相同的。 我还尝试将应用程序导出为可运行的应用程序,并从命令行独立运行,而不是通过 Eclipse - 结果相同。

我的应用程序不是一个长时间运行的网络应用程序等 - 只是一个调用我自己的其他一些类进行一些处理然后退出的主程序。

如果您对我可能做错的事情提出任何建议,我将不胜感激! :)

谢谢!

最佳答案

我也在为 VisualVM 苦苦挣扎,这很遗憾,因为它的用户界面非常棒,而它的分析输出看起来很可怕。你可以在这里看到我的问题。

Java VisualVM giving bizarre results for CPU profiling - Has anyone else run into this?

我可以告诉您一些关于 VisualVM 的奇怪知识以及它似乎进行分析的方式。

VisualVM 似乎正在计算在方法中花费的总时间(挂钟时间)。我的应用程序中有一个线程,它启动许多其他线程,然后立即阻塞等待队列中的消息。 VisualVM 不会在分析器中注册此方法,直到其他线程之一发送第一个线程正在等待的消息(当应用程序终止时)。突然,阻塞方法调用支配了分析输出,并被记录为占用了超过 80% 的应用程序时间。

其他探查器,例如 JProfiler 和 Azul 使用的探查器不会将阻塞的线程计算为探查器占用的时间。这意味着对于性能分析可能不感兴趣(取决于情况)的阻塞方法会模糊您对占用 CPU 时间的代码的看法。

当我运行我的分析时,我最终得到了

sun.rmi.transport.tcp.TCPTransport$ConnectionHandler.run()

一直隐藏我的分析,直到该消息返回到等待线程,然后这两个完全不相关的方法以及其他各种未出现在其他分析器上的无趣方法共享顶部位置。

其次,我认为方法过滤机制并没有像我预期的那样工作。这意味着我现在无法过滤掉我正在尝试追查的故事。

不是一个真正有用的答案。我现在看到的解决方案是为 JProfiler 付费 - VisualVM 对于这项任务似乎并不值得信赖。

关于java - 在 Java VisualVM 中看不到我自己的应用程序方法,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3243100/

有关java - 在 Java VisualVM 中看不到我自己的应用程序方法的更多相关文章

  1. ruby - 如何使用 Nokogiri 的 xpath 和 at_xpath 方法 - 2

    我正在学习如何使用Nokogiri,根据这段代码我遇到了一些问题:require'rubygems'require'mechanize'post_agent=WWW::Mechanize.newpost_page=post_agent.get('http://www.vbulletin.org/forum/showthread.php?t=230708')puts"\nabsolutepathwithtbodygivesnil"putspost_page.parser.xpath('/html/body/div/div/div/div/div/table/tbody/tr/td/div

  2. ruby - 如何从 ruby​​ 中的字符串运行任意对象方法? - 2

    总的来说,我对ruby​​还比较陌生,我正在为我正在创建的对象编写一些rspec测试用例。许多测试用例都非常基础,我只是想确保正确填充和返回值。我想知道是否有办法使用循环结构来执行此操作。不必为我要测试的每个方法都设置一个assertEquals。例如:describeitem,"TestingtheItem"doit"willhaveanullvaluetostart"doitem=Item.new#HereIcoulddotheitem.name.shouldbe_nil#thenIcoulddoitem.category.shouldbe_nilendend但我想要一些方法来使用

  3. ruby - 为什么我可以在 Ruby 中使用 Object#send 访问私有(private)/ protected 方法? - 2

    类classAprivatedeffooputs:fooendpublicdefbarputs:barendprivatedefzimputs:zimendprotecteddefdibputs:dibendendA的实例a=A.new测试a.foorescueputs:faila.barrescueputs:faila.zimrescueputs:faila.dibrescueputs:faila.gazrescueputs:fail测试输出failbarfailfailfail.发送测试[:foo,:bar,:zim,:dib,:gaz].each{|m|a.send(m)resc

  4. ruby - Facter::Util::Uptime:Module 的未定义方法 get_uptime (NoMethodError) - 2

    我正在尝试设置一个puppet节点,但ruby​​gems似乎不正常。如果我通过它自己的二进制文件(/usr/lib/ruby/gems/1.8/gems/facter-1.5.8/bin/facter)在cli上运行facter,它工作正常,但如果我通过由ruby​​gems(/usr/bin/facter)安装的二进制文件,它抛出:/usr/lib/ruby/1.8/facter/uptime.rb:11:undefinedmethod`get_uptime'forFacter::Util::Uptime:Module(NoMethodError)from/usr/lib/ruby

  5. ruby - 将差异补丁应用于字符串/文件 - 2

    对于具有离线功能的智能手机应用程序,我正在为Xml文件创建单向文本同步。我希望我的服务器将增量/差异(例如GNU差异补丁)发送到目标设备。这是计划:Time=0Server:hasversion_1ofXmlfile(~800kiB)Client:hasversion_1ofXmlfile(~800kiB)Time=1Server:hasversion_1andversion_2ofXmlfile(each~800kiB)computesdeltaoftheseversions(=patch)(~10kiB)sendspatchtoClient(~10kiBtransferred)Cl

  6. Ruby 方法() 方法 - 2

    我想了解Ruby方法methods()是如何工作的。我尝试使用“ruby方法”在Google上搜索,但这不是我需要的。我也看过ruby​​-doc.org,但我没有找到这种方法。你能详细解释一下它是如何工作的或者给我一个链接吗?更新我用methods()方法做了实验,得到了这样的结果:'labrat'代码classFirstdeffirst_instance_mymethodenddefself.first_class_mymethodendendclassSecond使用类#returnsavailablemethodslistforclassandancestorsputsSeco

  7. ruby-on-rails - Rails 3.2.1 中 ActionMailer 中的未定义方法 'default_content_type=' - 2

    我在我的项目中添加了一个系统来重置用户密码并通过电子邮件将密码发送给他,以防他忘记密码。昨天它运行良好(当我实现它时)。当我今天尝试启动服务器时,出现以下错误。=>BootingWEBrick=>Rails3.2.1applicationstartingindevelopmentonhttp://0.0.0.0:3000=>Callwith-dtodetach=>Ctrl-CtoshutdownserverExiting/Users/vinayshenoy/.rvm/gems/ruby-1.9.3-p0/gems/actionmailer-3.2.1/lib/action_mailer

  8. ruby-on-rails - Rails 应用程序之间的通信 - 2

    我构建了两个需要相互通信和发送文件的Rails应用程序。例如,一个Rails应用程序会发送请求以查看其他应用程序数据库中的表。然后另一个应用程序将呈现该表的json并将其发回。我还希望一个应用程序将存储在其公共(public)目录中的文本文件发送到另一个应用程序的公共(public)目录。我从来没有做过这样的事情,所以我什至不知道从哪里开始。任何帮助,将不胜感激。谢谢! 最佳答案 无论Rails是什么,几乎所有Web应用程序都有您的要求,大多数现代Web应用程序都需要相互通信。但是有一个小小的理解需要你坚持下去,网站不应直接访问彼此

  9. ruby - 无法运行 Rails 2.x 应用程序 - 2

    我尝试运行2.x应用程序。我使用rvm并为此应用程序设置其他版本的ruby​​:$rvmuseree-1.8.7-head我尝试运行服务器,然后出现很多错误:$script/serverNOTE:Gem.source_indexisdeprecated,useSpecification.Itwillberemovedonorafter2011-11-01.Gem.source_indexcalledfrom/Users/serg/rails_projects_terminal/work_proj/spohelp/config/../vendor/rails/railties/lib/r

  10. ruby - Highline 询问方法不会使用同一行 - 2

    设置:狂欢ruby1.9.2高线(1.6.13)描述:我已经相当习惯在其他一些项目中使用highline,但已经有几个月没有使用它了。现在,在Ruby1.9.2上全新安装时,它似乎不允许在同一行回答提示。所以以前我会看到类似的东西:require"highline/import"ask"Whatisyourfavoritecolor?"并得到:Whatisyourfavoritecolor?|现在我看到类似的东西:Whatisyourfavoritecolor?|竖线(|)符号是我的终端光标。知道为什么会发生这种变化吗? 最佳答案

随机推荐