gpt4 book ai didi

java - 在生产环境中远程监控 JVM

转载 作者:行者123 更新时间:2023-11-30 10:14:40 25 4
gpt4 key购买 nike

我用过jConsole ,通过其 GUI 监视 JVM,有时只需右键单击图形即可将性能数据保存到 csv。但现在我有一个需求,不使用 GUI,直接将远程 JVM 的堆内存使用率和 CPU 使用率等 JVM 性能数据写入本地文件(带有时间戳)。

我尝试过很多工具,包括以下工具,但它们没有所需的功能,例如连接到远程 JVM 和将输出写入本地文件。

  1. JVM Top
  2. JVM Mon

任何人都可以向我推荐一个可用于获取类似于通过 jConsole 生成的结果但不使用 GUI 的 csv 输出的工具。

最佳答案

我通常使用 cmdline-jmxclient 来拉取我的 MBean 数据,我使用 influx 来存储数据,然后在 Grafana 上显示它用于仪表板,下面是一个调用 jmxclient 的示例 shell 脚本

cmdline-jmxclient:

如果你有一个 MBean:com.yourcompany.data:type=datasystem,id=0使用名为的操作:jmxRefresh()

然后您可以编写一个简单的 bash 脚本(假设您下载了 cmdline-jmxclient-0.10.3.jar 并将其放在与您的脚本相同的目录中):

#!/bin/bash

cmdLineJMXJar=./cmdline-jmxclient-0.10.3.jar
user=yourUser
password=yourPassword
jmxHost=localhost
port=9003

#No User and password so pass '-'
echo "Available Operations for com.yourcompany.data:type=datasystem,id=0"
java -jar ${cmdLineJMXJar} ${user}:${password} ${jmxHost}:${port} com.yourcompany.data:type=datasystem,id=0

echo "Executing XML update..."
java -jar ${cmdLineJMXJar} - ${jmxHost}:${port} com.yourcompany.data:type=datasystem,id=0 jmxRefresh

同样,您可以获得堆内存或 JVM 中公开的任何其他 MBean。

另一个示例脚本如下

#!/bin/bash

if [ $# -ne 3 ]; then
echo "You need to supply both JMX host and port and metric. Exiting ..."
exit 1
fi

JAVA_BIN="/usr/bin/java"
JMX_CMDLINE="./cmdline-jmxclient-0.10.3.jar"
APP_NAME="${1}"

if [ $3 = "DaemonThreadCount" -o $3 = "all" ]; then

TEMPFILE=`mktemp`
$JAVA_BIN -jar $JMX_CMDLINE - ${1}:${2} "java.lang:type=Threading" DaemonThreadCount 2>> $TEMPFILE
VALUE=`grep DaemonThreadCount $TEMPFILE | sed "s/.*DaemonThreadCount: //g" | cut -f2 -d:`
echo "$VALUE"
rm -f $TEMPFILE

fi

if [ $3 = "HeapMemoryUsage" -o $3 = "all" ]; then

TEMPFILE=`mktemp`
$JAVA_BIN -jar $JMX_CMDLINE - ${1}:${2} "java.lang:type=Memory" HeapMemoryUsage 2>> $TEMPFILE

OUTPUT=`cat $TEMPFILE | egrep "committed:|used:" | sed "s/: /=/g"`

for line in $OUTPUT
do
NAME=`echo $line | cut -f1 -d=`
VALUE=`echo $line | cut -f2 -d=`
done

cat $TEMPFILE | grep used | cut -f2 -d" "
rm -f $TEMPFILE

fi


if [ $3 = "PSPermGen" -o $3 = "all" ]; then

rm -f $TEMPFILE

$JAVA_BIN -jar $JMX_CMDLINE - ${1}:${2} "java.lang:name=PS Perm Gen,type=MemoryPool" Usage 2>> $TEMPFILE

OUTPUT=`cat $TEMPFILE | egrep "committed:|used:" | sed "s/: /=/g"`

for line in $OUTPUT
do
NAME=`echo $line | cut -f1 -d=`
VALUE=`echo $line | cut -f2 -d=`
echo "$VALUE"
done

fi

关于java - 在生产环境中远程监控 JVM,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/50794226/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com