一、问题描述:
NMT开启后,jcmd <PID> VM.native_memory报错:
com.sun.tools.attach.AttachNotSupportedException: Unable to open socket file: target process not responding or HotSpot VM not loaded
at sun.tools.attach.LinuxVirtualMachine.<init>(LinuxVirtualMachine.java:106)
at sun.tools.attach.LinuxAttachProvider.attachVirtualMachine(LinuxAttachProvider.java:63)
at com.sun.tools.attach.VirtualMachine.attach(VirtualMachine.java:208)
at sun.tools.jcmd.JCmd.executeCommandForPid(JCmd.java:147)
at sun.tools.jcmd.JCmd.main(JCmd.java:131)

二、问题解决:
检查发现java应用是由特定用户启动的,不是root启动的,jcmd需要使用与进程一致的用户才能执行,通过ps可以看到启动项目的用户。切换用户后执行成功。
当尝试使用jcmd查询NMT(NativeMemoryTracking)时,遇到AttachNotSupportedException,原因是非root用户尝试访问进程。解决方案是确认并切换到与Java应用相同用户的上下文中执行命令,这样可以成功运行jcmd。
2941

被折叠的 条评论
为什么被折叠?



