李锋镝的博客

  • 首页
  • 时间轴
  • 插件
  • 评论区显眼包🔥
  • 左邻右舍
  • 博友圈
  • 关于我
    • 关于我
    • 另一个网站
    • 我的导航站
    • 网站地图
  • 留言
  • 赞助
Destiny
自是人生长恨水长东
  1. 首页
  2. 原创
  3. 正文

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

2025年4月9日 59点热度 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/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
取消回复

我见青山多妩媚,料青山见我应如是。

历史上的今天(12月13日)

  • 2009年:美国诺贝尔经济学奖第一人萨缪尔森逝世
  • 2001年:美国宣布退出《反导条约》
  • 1974年:马耳他宣布成为共和国
  • 1971年:美、法总统发表联合公报宣布美元贬值
  • 1553年:法国国王亨利四世出生
  • 更多历史事件
最新 热点 随机
最新 热点 随机
Java进阶实战:10个高效技巧+环境管理指南,让代码简洁又优雅 Gemini 3 Pro 深度测评:多模态AI编程的跨代际突破,从一句话到完整应用的全链路革命 6款核心MCP协议工具让AI深度融入业务,告别“纸上谈兵” Python 3.12并发革命:大厂争相升级的底层逻辑与实战指南 TIOBE 12月榜单:C#有望摘得年度语言,R语言重返Top 10 WordPress实现用户评论等级排行榜插件
玩博客的人是不是越来越少了?准备入手个亚太的ECS,友友们有什么建议吗?使用WireGuard在Ubuntu 24.04系统搭建VPNWordPress实现用户评论等级排行榜插件Gemini 3 Pro 深度测评:多模态AI编程的跨代际突破,从一句话到完整应用的全链路革命双 Token 机制
蓝奏云地址怎么天天失效…… SpringBoot使用RestTemplate进行接口调用 揭秘大模型Token的诞生:从字节到子词的分词逻辑与底层算法 多层嵌套map对象转扁平化map 网站使用HarmonyOSHans字体 打造AI应用的高颜值答案展示:基于Vue3.5+MarkdownIt构建专业级富文本渲染组件
标签聚合
数据库 JAVA IDEA 架构 AIGC 多线程 docker JVM AI编程 MySQL Spring ElasticSearch 分布式 SpringBoot 设计模式 AI Redis SQL K8s 日常
友情链接
  • 临窗旋墨
  • 哥斯拉
  • 彬红茶日记
  • 志文工作室
  • 搬砖日记
  • 旧时繁华
  • 林羽凡
  • 瓦匠个人小站
  • 皮皮社
  • 知向前端
  • 蜗牛工作室
  • 韩小韩博客
  • 风渡言

COPYRIGHT © 2025 lifengdi.com. ALL RIGHTS RESERVED.

Theme Kratos Made By Dylan

津ICP备2024022503号-3