您的位置:首页 >Java在CentOS上的性能监控怎么做
发布于2026-05-02 阅读(0)
扫一扫,手机访问
当线上应用出现响应迟缓或资源告警时,一套清晰、高效的性能监控流程就是运维和开发人员的“听诊器”。下面,我们就从系统巡检到深度诊断,梳理一遍在 CentOS 环境下定位 Ja va 应用性能问题的实战路径。
在深入 JVM 之前,先从系统全局视角快速扫一眼,这能帮你迅速定位问题的大致方向。
ps -ef | grep ja va 当然能用,但更专业的工具是 jps -v(直接列出进程号和启动参数)或 pgrep -af ja va。top -p 盯住目标进程,记得按 1 键展开所有 CPU 核心的详情。如果习惯更直观的界面,可以安装 htop。nmon 或 dstat -ta 1 这类综合工具是不二之选。df -h 看磁盘空间,free -m 看内存余量,这是排查存储类问题的第一步。系统层面没问题?那问题很可能就藏在 JVM 内部了。这时,JDK 自带的一套工具链就该登场了。
jstat -gcutil <间隔秒> <次数> :这是观察 GC 健康状况的“仪表盘”,能实时查看各代内存使用率和 GC 次数/时间,快速判断 GC 压力。jstack :抓取线程快照的利器。无论是死锁,还是大量线程卡在 RUNNABLE、BLOCKED、WAITING 状态,它都能让问题现形。jmap -heap :查看堆内存配置与使用概况。而 jmap -dump:format=b,file=heap.hprof 则用于生成堆转储文件,是分析内存泄漏的“原始素材”。jinfo :用来查看或动态调整 JVM 参数,比如核对或修改 -Xms、-Xmx、-XX:+UseG1GC 等。jps -v:再次强调它,因为它能最直接地列出所有 Ja va 进程及其启动参数,是核对配置的快捷方式。jstat -gcutil 12345 2s 30jstack 12345 > threads.txtjmap -dump:format=b,file=heap.hprof 12345ja va -jar arthas-boot.jar 选择进程后,使用 dashboard、thread、heapdump 等命令。对于需要长期观察和告警的场景,命令行工具就显得力不从心了。这时,就需要构建指标化监控体系。
/actuator/health、/metrics、/prometheus 等端点,轻松实现健康检查和指标暴露。很多时候,问题的答案就藏在日志里。高效的日志分析是定位问题的最后一道,也是信息量最大的一道关卡。
ps -ef | grep ja va 查看启动参数中的 -Dlogging.file=,或寻找常见的 catalina.out(Tomcat)。tail -f app.log | grep “ERROR” 是经典操作,也可以根据特定关键字或时间窗口进行检索。top 找到高占用的线程 ID,将其转换为十六进制(printf “%x\n” <线程ID>),然后在 jstack 输出中搜索 nid=0x… 对应的线程栈。jmap 导出堆转储文件,然后导入 Eclipse MAT 等工具,分析 Dominator Tree 或 Leak Suspects 报告。WAITING on condition,或者日志中频繁出现数据库、HTTP 调用超时,都指向 I/O 瓶颈。logrotate 等工具实现日志的按日切分、压缩和定期清理,便于归档和检索历史问题。将上述常用检查点固化成一个脚本,能极大提升日常巡检和应急响应的效率。
check_ja va.sh,赋予执行权限后运行:chmod +x check_ja va.sh && ./check_ja va.sh your-app.jar#!/usr/bin/env bash
set -euo pipefail
APP_NAME="${1:-myapp.jar}"
PID=$(pgrep -f "$APP_NAME" | head -n1)
if [[ -z "$PID" ]]; then
echo "[ERROR] $APP_NAME is NOT running."
exit 1
fi
echo "=== $APP_NAME (PID=$PID) Health Check ==="
echo "[1/5] CPU/Memory (top):"
top -b -n1 -p "$PID" | head -n12
echo -e "\n[2/5] GC Summary (jstat):"
jstat -gcutil "$PID" 1 1
echo -e "\n[3/5] Thread Count (jstack):"
jstack "$PID" | grep -E 'ja va.lang.Thread.State' | sort | uniq -c
echo -e "\n[4/5] Open Files / Connections:"
ls -1 /proc/"$PID"/fd 2>/dev/null | wc -l
ss -tnp | grep -E "pid=$PID" | wc -l
echo -e "\n[5/5] Recent Errors in Logs (last 200 lines):"
LOG=$(ps -ef | grep "$APP_NAME" | grep -Eo '-Dlogging.file=[^ ]+' | cut -d= -f2 || echo "/var/log/$APP_NAME.log")
[[ -f "$LOG" ]] && tail -n200 "$LOG" | grep -i "ERROR" | tail -n20 || echo "Log file not found: $LOG"
售后无忧
立即购买>office旗舰店
售后无忧
立即购买>office旗舰店
售后无忧
立即购买>office旗舰店
售后无忧
立即购买>office旗舰店
正版软件
正版软件
正版软件
正版软件
正版软件
1
2
3
7
9