0

我有一个 JAVA 应用程序,我想使用telegraf工具监视它的 JMX 属性。

该工具提供jolikia插件来监控 JMX 属性。我已在我的应用程序pom.xml文件中添加了以下有关Jolokia 文档Maven部分的依赖项:

<dependency>
    <groupId>org.jolokia</groupId>
    <artifactId>jolokia-core</artifactId>
    <version>1.3.7</version>
</dependency>
<dependency>
    <groupId>org.jolokia</groupId>
    <artifactId>jolokia-client-java</artifactId>
    <version>1.3.7</version>
</dependency>

这是我的/etc/telegraf/telegraf.conf文件:

[[inputs.jolokia]]

   context = "/jolokia/"
   [[inputs.jolokia.servers]]
       name = "wr-core"
       host = "192.168.100.175"
       port = "1998"

   [[inputs.jolokia.metrics]]
       name = "send_success"
       mbean  = "wr-core:type=monitor,name=execution"
       attribute = "MessageSendSuccessCount"

该应用程序在提供的 IP/端口中启动(我可以使用 连接到它jconsole)。该应用程序有一个监控部分,其对象名称(如 中所示jconsole)是wr-core:type=monitor,name=execution并且具有属性MessageSendSuccessCount。但是当我启动telegraf服务时,会出现以下错误:

Jan 14 14:30:32 ZiZi telegraf[17258]: 2018-01-14T11:00:32Z E! Error in plugin [inputs.jolokia]: error performing request: Error decoding JSON response: invalid character '\x00' looking for beginning of value:

请注意,这1998是我的应用程序的 jmx 端口。我也尝试使用8778which is jolokia-agentport; 拿到:

Jan 14 14:40:03 ZiZi telegraf[9150]: 2018-01-14T11:10:03Z E! Error in plugin [inputs.jolokia]: error performing request: Post http://192.168.100.175:8778/jolokia/: dial tcp 192.168.100.175:8778: getsockopt: connection refused

编辑1:

我已经检查了我的CLASSPATH和两者jolokia-client并被jolokia-core列出:../lib/jolokia-client-java-1.3.7.jar:../lib/jolokia-core-1.3.7.jar

编辑2:

我已将以下几行放入我的应用程序的执行文件中:

JOLOKIA_OPTS=-javaagent:$LIB_PATH/jolokia-core-java-1.3.7.jar=port=8778,host=0.0.0.0

JAVA_OPTS="-mx4096M $JAVA_OPTS $JACOCO_OPTS $JOLOKIA_OPTS"

但是当我运行该文件时,我得到了这个错误(即使../lib/jolokia-core-java-1.3.7.jar已在 中列出CLASSPATH):

Error opening zip file or JAR manifest missing : ../lib/jolokia-core-java-1.3.7.jar
Error occurred during initialization of VM
agent library failed to init: instrument
4

1 回答 1

1

找到了解决方案。

我跳过了maven解决方案并尝试了该javaagent方法,但我误解了之前的用法javaagent;我应该解决jolokia jvm 代理有帮助):

JOLOKIA_OPTS=-javaagent:/root/jolokia-jvm-1.3.7-agent.jar=port=8778,host=0.0.0.0
JAVA_OPTS="-mx4096M $JAVA_OPTS $JACOCO_OPTS $JOLOKIA_OPTS"

现在,我的应用程序从这个日志开始(成功):

I> No access restrictor found, access to any MBean is allowed
Jolokia: Agent started with URL http://192.168.100.175:8778/jolokia/

在另一边,telegraf控制台中jolokia不再有错误。

所有观察结果都表明 jolokia jvm 库已启动并成功运行。

我还找到了 jolokia jmx 文档,用于将其用作项目中的依赖项;但由于我不是 JAVA 专家(我正在测试应用程序),我更喜欢目前使用该javaagent方法并将其留待将来学习/体验。顺便说一句,它可能会帮助其他人。

编辑1:

我已经找到并jolokia jvm agent使用它的spring support进行部署。

在 XML 文件中配置它spring,我现在可以jolokia jvm agent在我的应用程序启动时开始监听。

于 2018-01-15T09:03:17.603 回答