李锋镝的博客

  • 首页
  • 时间轴
  • 留言
  • 插件
  • 左邻右舍
  • 关于我
    • 关于我
    • 另一个网站
  • 知识库
  • 赞助
Destiny
自是人生长恨水长东
  1. 首页
  2. 原创
  3. 正文

解决Cannot connect to core dump or remote debug server. Use jhsdb jmap instead

2025年4月9日 259点热度 0人点赞 0条评论

今天排查线上问题的时候,执行jmap -heap 1遇见一个报错:

Error: -heap option used
Cannot connect to core dump or remote debug server. Use jhsdb jmap instead

这是因为在较新的 JDK 版本中,jmap 工具的一些功能被 jhsdb jmap 替代了,特别是在连接核心转储文件或远程调试服务器时。

1. 使用 jhsdb jmap 替代 jmap -heap

jhsdb jmap 是 JDK 9 及更高版本中推荐使用的工具,可用于替代 jmap 的部分功能。你可以使用以下命令来查看指定进程的堆内存信息:

jhsdb jmap --heap --pid 1

这里的 1 是 Java 进程的 PID,你要根据实际情况进行替换。

2. 命令详细解释

  • jhsdb:JDK 提供的一个诊断工具,可用于分析 Java 进程、核心转储文件等。
  • jmap:是 jhsdb 的一个子命令,用于执行与内存映射相关的操作。
  • --heap:指定要查看堆内存的详细信息,如堆的配置、各代的使用情况等。
  • --pid:用于指定要分析的 Java 进程的 ID。

3. 示例操作步骤

步骤 1:确认 Java 进程的 PID

你可以使用 jps 命令来查看当前系统中所有 Java 进程的 PID:

jps

输出示例:

1234 MainClass
5678 AnotherClass

这里的 1234 和 5678 就是 Java 进程的 PID。

步骤 2:使用 jhsdb jmap 查看堆内存信息

假设要查看 PID 为 1234 的 Java 进程的堆内存信息,可以执行以下命令:

jhsdb jmap --heap --pid 1234

执行该命令后,会输出堆内存的详细信息,包括堆的配置信息、各代的使用情况等,示例输出如下:

Attaching to process ID 1234, please wait...
Debugger attached successfully.
Server compiler detected.
JVM version is 25.202-b08

using thread-local object allocation.
Parallel GC with 8 thread(s)

Heap Configuration:
   MinHeapFreeRatio         = 0
   MaxHeapFreeRatio         = 100
   MaxHeapSize              = 2147483648 (2048.0MB)
   NewSize                  = 44564480 (42.5MB)
   MaxNewSize               = 715520000 (682.375MB)
   OldSize                  = 89653248 (85.5MB)
   NewRatio                 = 2
   SurvivorRatio            = 8
   MetaspaceSize            = 21807104 (20.796875MB)
   CompressedClassSpaceSize = 1073741824 (1024.0MB)
   MaxMetaspaceSize         = 17592186044415 MB
   G1HeapRegionSize         = 0 (0.0MB)

Heap Usage:
PS Young Generation
Eden Space:
   capacity = 36700160 (35.0MB)
   used     = 18350080 (17.5MB)
   free     = 18350080 (17.5MB)
   50.0% used
From Space:
   capacity = 4456448 (4.25MB)
   used     = 0 (0.0MB)
   free     = 4456448 (4.25MB)
   0.0% used
To Space:
   capacity = 4456448 (4.25MB)
   used     = 0 (0.0MB)
   free     = 4456448 (4.25MB)
   0.0% used
PS Old Generation
   capacity = 89653248 (85.5MB)
   used     = 44826624 (42.75MB)
   free     = 44826624 (42.75MB)
   50.0% used
除非注明,否则均为李锋镝的博客原创文章,转载必须以链接形式标明本文链接

本文链接:https://www.lifengdi.com/archives/article/4310

相关文章

  • 金融级JVM深度调优实战的经验和技巧
  • JVM参数-XX:InitialRAMPercentage 和 -XX:MaxRAMPercentage解析
  • Java触发GC的方式
  • 分代ZGC这么牛?底层原理是什么?
  • jmap命令(jdk1.8)
本作品采用 知识共享署名-非商业性使用-相同方式共享 4.0 国际许可协议 进行许可
标签: JAVA jhsdb jmap JVM
最后更新:2025年4月9日

李锋镝

既然选择了远方,便只顾风雨兼程。

打赏 点赞
< 上一篇
下一篇 >

文章评论

1 2 3 4 5 6 7 8 9 11 12 13 14 15 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 46 47 48 49 50 51 52 53 54 55 57 58 60 61 62 63 64 65 66 67 69 72 74 76 77 78 79 80 81 82 85 86 87 90 92 93 94 95 96 97 98 99
取消回复

人生自古谁无死?留取丹心照汗青。

最新 热点 随机
最新 热点 随机
SpringBoot框架自动配置之spring.factories和AutoConfiguration.imports 应用型负载均衡(ALB)和网络型负载均衡(NLB)区别 什么是Helm? TransmittableThreadLocal介绍与使用 ReentrantLock深度解析 RedisTemplate和Redisson的区别
玩博客的人是不是越来越少了?准备入手个亚太的ECS,友友们有什么建议吗?什么是Helm?2024年11月1号 农历十月初一别再背线程池的七大参数了,现在面试官都这么问URL地址末尾加不加“/”有什么区别
透过现象看本质:Java类动态加载和热替换 WordPress的自动更新好烦啊 终于有人把Elasticsearch原理讲透了! 解决Intellij IDEA运行报Command line is too long的问题 解决MacBookPro-M4启动SpringCloud Gateway,首次访问巨慢问题 Java数组类型
标签聚合
分布式 SQL 文学 JVM Redis 架构 MySQL Spring 面试 数据库 设计模式 多线程 JAVA docker IDEA ElasticSearch 教程 K8s 日常 SpringBoot
友情链接
  • i架构
  • 临窗旋墨
  • 博友圈
  • 博客录
  • 博客星球
  • 哥斯拉
  • 志文工作室
  • 搬砖日记
  • 旋律的博客
  • 旧时繁华
  • 林羽凡
  • 知向前端
  • 蜗牛工作室
  • 集博栈
  • 韩小韩博客
  • 風の声音

COPYRIGHT © 2025 lifengdi.com. ALL RIGHTS RESERVED.

Theme Kratos Made By Dylan

津ICP备2024022503号-3