[Bug 3237] New: JvmStatDataExtractor might throw monitor exception on retrieving certain info of a JVM
bugzilla-daemon at icedtea.classpath.org
bugzilla-daemon at icedtea.classpath.org
Wed Nov 23 16:32:11 UTC 2016
http://icedtea.classpath.org/bugzilla/show_bug.cgi?id=3237
Bug ID: 3237
Summary: JvmStatDataExtractor might throw monitor exception on
retrieving certain info of a JVM
Product: Thermostat
Version: hg
Hardware: x86_64
OS: Linux
Status: NEW
Severity: enhancement
Priority: P5
Component: agent
Assignee: unassigned at icedtea.classpath.org
Reporter: sgehwolf at redhat.com
CC: thermostat at icedtea.classpath.org
I'm seeing an issue where the JVM does not get detected by thermostat due to an
exception being thrown before the actual vm-info record gets created:
Nov 23, 2016 3:15:35 PM
com.redhat.thermostat.backend.system.JvmStatHostListener vmStatusChanged
WARNING: error getting info for new vm 1
sun.jvmstat.monitor.MonitorException: Could not synchronize with target
at
sun.jvmstat.perfdata.monitor.v2_0.PerfDataBuffer.synchWithTarget(PerfDataBuffer.java:277)
at
sun.jvmstat.perfdata.monitor.v2_0.PerfDataBuffer.buildMonitorMap(PerfDataBuffer.java:131)
at
sun.jvmstat.perfdata.monitor.PerfDataBufferImpl.findByName(PerfDataBufferImpl.java:241)
at
sun.jvmstat.perfdata.monitor.AbstractPerfDataBuffer.findByName(AbstractPerfDataBuffer.java:100)
at
sun.jvmstat.perfdata.monitor.AbstractMonitoredVm.findByName(AbstractMonitoredVm.java:85)
at
com.redhat.thermostat.backend.system.JvmStatDataExtractor.getJavaVersion(JvmStatDataExtractor.java:78)
at
com.redhat.thermostat.backend.system.JvmStatHostListener.createVmInfo(JvmStatHostListener.java:161)
at
com.redhat.thermostat.backend.system.JvmStatHostListener.sendNewVM(JvmStatHostListener.java:135)
at
com.redhat.thermostat.backend.system.JvmStatHostListener.vmStatusChanged(JvmStatHostListener.java:103)
at
sun.jvmstat.perfdata.monitor.protocol.local.MonitoredHostProvider.fireVmStatusChangedEvents(MonitoredHostProvider.java:177)
at
sun.jvmstat.perfdata.monitor.protocol.local.MonitoredHostProvider.access$300(MonitoredHostProvider.java:41)
at
sun.jvmstat.perfdata.monitor.protocol.local.MonitoredHostProvider$NotifierTask.run(MonitoredHostProvider.java:218)
at java.util.TimerThread.mainLoop(Timer.java:555)
at java.util.TimerThread.run(Timer.java:505)
The JVM itself (the pid) is there, but figuring out the Java Version for that
JVM process fails. This looks a lot like these JDK bugs:
http://bugs.java.com/bugdatabase/view_bug.do?bug_id=6637230
http://bugs.java.com/bugdatabase/view_bug.do?bug_id=6602355
I'll try to create a simple reproducer for this. Either way, it should not fail
to create the vm-info record. Instead, it should fill in some
place-holder-value like "X unavailable" and once it does become available it
should update it.
Running jps on this system returns:
1 -- main class information unavailable
and once that JVM properly settles it changes to:
1 Bootstrap
--
You are receiving this mail because:
You are the assignee for the bug.
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://mail.openjdk.java.net/pipermail/distro-pkg-dev/attachments/20161123/d371662c/attachment-0001.html>
More information about the distro-pkg-dev
mailing list