当前位置: 首页 > wzjs >正文

做网站需要自己上传产品吗北京做的好的seo公司

做网站需要自己上传产品吗,北京做的好的seo公司,江西机场建设集团网站,wordpress免费字体jcmd 是 Oracle JDK(Java Development Kit)自 JDK 7 起引入的一个强大的诊断工具,用于与正在运行的 JVM(Java Virtual Machine)实例进行交互。它允许用户执行各种诊断命令,比如线程堆栈分析、堆转储、GC 信…

jcmd 是 Oracle JDK(Java Development Kit)自 JDK 7 起引入的一个强大的诊断工具,用于与正在运行的 JVM(Java Virtual Machine)实例进行交互。它允许用户执行各种诊断命令,比如线程堆栈分析、堆转储、GC 信息、类加载器统计等,非常适合在生产环境中对 Java 应用程序进行调试和监控。

一、jcmd 命令基本语法

jcmd <pid | main-class> <command> [options]
  • <pid>:目标 Java 进程的进程 ID。
  • <main-class>:目标 Java 应用的主类名(可以省略 jar 路径)。
  • <command>:具体的诊断命令,比如 VM.flags
  • [options]:命令附带的参数(具体取决于命令)。

二、查看可用的 Java 进程

jcmd
输出
970 com.dzy.Main
67890 org.apache.catalina.startup.Bootstrap

表示当前有两个 Java 进程在运行,它们的进程 ID 分别是 970 和 67890。


三、常用命令详解与使用示例

1. 查看所有支持的命令

jcmd <pid> help
用法
jcmd 970 help
输出

列出该 JVM 实例支持的所有命令:

970:
VM.version
VM.command_line
VM.flags
Thread.print
GC.heap_info
GC.run
GC.class_histogram
...

2. 查看 JVM 版本信息

jcmd <pid> VM.version
用法
jcmd 970 VM.version
输出
970:
Java HotSpot(TM) 64-Bit Server VM version 17.0.9+11-LTS-201
JDK 17.0.9

3. 查看启动参数

jcmd <pid> VM.command_line
用法
jcmd 970 VM.command_line
输出
Command line:  -Xmx2G -Xms1G -Dspring.profiles.active=prod -jar app.jar

4. 查看 JVM 参数(flags)

jcmd <pid> VM.flags
用法
jcmd 970 VM.flags
输出
-XX:InitialHeapSize=1073741824 -XX:MaxHeapSize=2147483648 -XX:+UseG1GC

5. 打印线程堆栈(类似 jstack

jcmd <pid> Thread.print
用法
jcmd 970 Thread.print
输出

列出所有线程的栈信息,包括锁等待、阻塞等,非常适合死锁分析。

6. 强制触发 GC

jcmd <pid> GC.run
用法
jcmd 970 GC.run

此命令不会显示太多输出,但会触发一次完全 GC。

7. 获取堆信息(heap 使用情况)

jcmd <pid> GC.heap_info
用法
jcmd 970 GC.heap_info
输出
Heap Configuration:MinHeapFreeRatio         = 40MaxHeapFreeRatio         = 70...
Heap Usage:G1 Heap:regions  = 2048capacity = 2048Mused     = 1024Mfree     = 1024M

8. 导出 heap dump(堆快照)

jcmd <pid> GC.heap_dump /path/to/heapdump.hprof
用法
jcmd 970 GC.heap_dump /tmp/app-heap.hprof

文件可以用 MAT 或 VisualVM 分析。

9. 类直方图(类实例计数)

jcmd <pid> GC.class_histogram
用法
jcmd 970 GC.class_histogram
或者输出到文件
jcmd 970 GC.class_histogram > histogram.txt
输出
 num     #instances         #bytes  class name
----------------------------------------------1:        10000        1600000  [C2:         5000         800000  java.lang.String3:         3000         720000  java.util.HashMap

10. 导出类加载器信息

jcmd <pid> VM.class_loader_stats
用法
jcmd 970 VM.class_loader_stats
输出

统计各类加载器加载的类数量、占用内存等信息。

11. 检查是否发生了死锁

jcmd <pid> Thread.print
用法
jcmd 970 Thread.print

系统会显示哪些线程在等待锁、拥有锁,如果存在死锁,会提示 Found one Java-level deadlock.

12. 查看 Metaspace 使用情况

jcmd <pid> VM.native_memory summary
用法
jcmd 970 VM.native_memory summary

需要启动 JVM 时开启:

-XX:NativeMemoryTracking=summary

13. 查看系统属性(类似 System.getProperties)

jcmd <pid> VM.system_properties
用法
jcmd 970 VM.system_properties

14. 使用 Java Flight Recorder(JDK 11+)

JFR.start, JFR.dump, JFR.stop

# 启动 JFR
jcmd 970 JFR.start name=profile settings=profile duration=60s filename=/tmp/recording.jfr# 手动 dump
jcmd 970 JFR.dump name=profile filename=/tmp/manual.jfr# 停止 JFR
jcmd 970 JFR.stop name=profile

15. 查看 JIT 编译缓存区状态

jcmd <pid> Compiler.codecache
用法
jcmd 970 Compiler.codecache

四、常见场景使用

性能监控中查看当前内存使用情况

jcmd $(pidof java) GC.heap_info

导出内存快照进行 OOM 分析

jcmd $(pidof java) GC.heap_dump /tmp/dump-$(date +%s).hprof

分析线程死锁或阻塞线程

jcmd $(pidof java) Thread.print > /tmp/thread-dump.log

定时触发 GC 以排查内存回收异常

watch -n 60 "jcmd $(pidof java) GC.run"

Java 服务卡顿,想排查是否 GC 频繁

jcmd <pid> GC.heap_info
jcmd <pid> GC.class_histogram
jcmd <pid> GC.run
jcmd <pid> GC.class_histogram

比较前后对象数量是否减少,分析垃圾回收效率。

服务 CPU 飙高,定位是哪条线程

  1. 查看线程信息(找到耗 CPU 的线程)
top -Hp <pid>
  1. 将该线程 TID 转为十六进制(假设是 970 → 0x3039)
print "%x/n" <pid>
  1. jcmd 输出中查找栈
jcmd <pid> Thread.print | grep -A 20 0x3039

导出类实例占用查看内存增长

jcmd <pid> GC.class_histogram > before.txt
# 10分钟后
jcmd <pid> GC.class_histogram > after.txt
diff before.txt after.txt

分析 JVM 启动参数差异

jcmd <pid> VM.flags
jcmd <pid> VM.command_line

五、注意

  • jcmd 只能对当前用户启动的 Java 进程使用,或者以 root 权限运行。
  • 输出信息比较多,建议重定向到文件进行分析。
  • jstackjmap 等相比,jcmd 更统一、更高效。
功能命令
查看进程列表jcmd
查看支持命令jcmd <pid> help
JVM 版本jcmd <pid> VM.version
JVM 启动参数jcmd <pid> VM.command_line / VM.flags
手动 GCjcmd <pid> GC.run
打印线程堆栈jcmd <pid> Thread.print
类占用分析jcmd <pid> GC.class_histogram
原生内存jcmd <pid> VM.native_memory summary
启动/导出 JFRjcmd <pid> JFR.*
http://www.dtcms.com/wzjs/153029.html

相关文章:

  • 建设一个自己的网站需要多少钱在线查网站的ip地址
  • bootstrap做自己的网站苏州seo整站优化
  • 做网站用哪个软件最好php苏州网站建设公司
  • 重庆网站建设 吧如何打百度人工电话
  • 网站自己怎么做优化宁波seo高级方法
  • wordpress永久链接无效关键词优化软件排行
  • 长沙网站排名方法山东seo首页关键词优化
  • 做资讯类网站如何做网页
  • 工控做网站网络软营销
  • 玉溪网站建设高效统筹疫情防控和经济社会发展
  • 滨海专业做网站的公司广告策划公司
  • 宿州哪家做网站好长春网站建设方案咨询
  • 怎么进行网站关键词优化企业网站设计代码
  • 武汉品牌网站开发seo顾问服务公司站长
  • 网站动效怎么做的百度小说风云榜排名
  • 厦门市建设管理协会网站首页永久免费国外域名注册
  • 网站建设实训实训心得天津海外seo
  • 网站 源码 下载seo排名赚app靠谱吗
  • 济源哪里做网站网络营销的目标
  • 驻马店网站建设武汉网站制作推广
  • 手机网站建设书籍百度指数是搜索量吗
  • 动态网站开发软件百度站长平台快速收录
  • 网站后台管理系统界面青岛网站快速排名优化
  • 网站开发使用的工具网络营销方案的制定
  • 河北邢台企业做网站产品推广方式
  • 风险报告查询系统优化网站推广排名
  • 自己做的网站如何用手机去查看比较好的网络优化公司
  • wordpress仿国际seo定义
  • 网站自适应框架网站搭建策略与方法
  • 开封市建设中专继续教育网站今日国际重大新闻