zabbix JMX监控kafka

时间:2014-07-09 10:49:05

标签: java jmx zabbix

我试图通过zabbix java网关从zabbix监控java app Apache Kafka Server,我对zabbix设置有点挣扎。我能够监控像LoadedClassCount等JVM标准指标。但是我找不到适当的Kafka指标设置。

JConsole kafka JMX attributes

我的zabbix java网关JMX密钥如下:

jmx["kafka.server.BrokerTopicMetrics:type=AllTopicsMessagesInPerSec",Count]

我尝试了各种组合但到目前为止没有运气。什么提示可能有什么问题?

似乎JMX对象是嵌套的。

更新: 我尝试使用标准JVM MBean来复制避免使用Kafka MBean的情况 Standard JVM MBean

使用Zabbix配置

jmx[java.lang:type=GarbageCollector,ConcurrentMarkSweep.CollectionCount]

我在日志中遇到异常:

2014-07-09 08:00:11.664 [pool-1-thread-5] DEBUG com.zabbix.gateway.ItemChecker - caught exception for item 'jmx[java.lang:type=GarbageCollector,ConcurrentMarkSweep.CollectionCount]'
javax.management.InstanceNotFoundException: java.lang:type=GarbageCollector
        at com.sun.jmx.interceptor.DefaultMBeanServerInterceptor.getMBean(DefaultMBeanServerInterceptor.java:1118) ~[na:1.6.0_24]
        at com.sun.jmx.interceptor.DefaultMBeanServerInterceptor.getAttribute(DefaultMBeanServerInterceptor.java:679) ~[na:1.6.0_24]
        at com.sun.jmx.mbeanserver.JmxMBeanServer.getAttribute(JmxMBeanServer.java:672) ~[na:1.6.0_24]
        at javax.management.remote.rmi.RMIConnectionImpl.doOperation(RMIConnectionImpl.java:1427) ~[na:1.6.0_24]
        at javax.management.remote.rmi.RMIConnectionImpl.access$200(RMIConnectionImpl.java:90) ~[na:1.6.0_24]
        at javax.management.remote.rmi.RMIConnectionImpl$PrivilegedOperation.run(RMIConnectionImpl.java:1285) ~[na:1.6.0_24]
        at javax.management.remote.rmi.RMIConnectionImpl.doPrivilegedOperation(RMIConnectionImpl.java:1383) ~[na:1.6.0_24]
        at javax.management.remote.rmi.RMIConnectionImpl.getAttribute(RMIConnectionImpl.java:619) ~[na:1.6.0_24]
        at sun.reflect.GeneratedMethodAccessor82.invoke(Unknown Source) ~[na:na]
        at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) ~[na:1.6.0_24]
        at java.lang.reflect.Method.invoke(Method.java:616) ~[na:1.6.0_24]
        at sun.rmi.server.UnicastServerRef.dispatch(UnicastServerRef.java:322) ~[na:1.6.0_24]
        at sun.rmi.transport.Transport$1.run(Transport.java:177) ~[na:1.6.0_24]
        at java.security.AccessController.doPrivileged(Native Method) ~[na:1.6.0_24]
        at sun.rmi.transport.Transport.serviceCall(Transport.java:173) ~[na:1.6.0_24]
        at sun.rmi.transport.tcp.TCPTransport.handleMessages(TCPTransport.java:553) ~[na:1.6.0_24]
        at sun.rmi.transport.tcp.TCPTransport$ConnectionHandler.run0(TCPTransport.java:808) ~[na:1.6.0_24]
        at sun.rmi.transport.tcp.TCPTransport$ConnectionHandler.run(TCPTransport.java:667) ~[na:1.6.0_24]
        at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1110) [na:1.6.0_24]
        at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:603) [na:1.6.0_24]
        at java.lang.Thread.run(Thread.java:679) [na:1.6.0_24]

THX

2 个答案:

答案 0 :(得分:2)

已解决,以下为我工作

jmx["\"kafka.server\":type=\"BrokerTopicMetrics\",name=\"AllTopicsMessagesInPerSec\"",Count]

答案 1 :(得分:2)

我一直在敲打这个问题。这对我有用:

jmx["kafka.server:type=BrokerTopicMetrics,name=MessagesInPerSec",Count]

Zabbix v2.2.2