0

デバッグしたい Java プロセスがあります。問題は、開いている接続が多すぎるため、プロセスに接続できないために jmap の実行が失敗することです。jmap -F を実行すると、次のエラーが発生します。

Attaching to process ID 1772, please wait...
sun.jvm.hotspot.debugger.NoSuchSymbolException: Could not find symbol "gHotSpotVMTypeEntryTypeNameOffset" in any of the known library names (libjvm.so, libjvm_g.so, gamma_g)
        at sun.jvm.hotspot.HotSpotTypeDataBase.lookupInProcess(HotSpotTypeDataBase.java:388)
        at sun.jvm.hotspot.HotSpotTypeDataBase.getLongValueFromProcess(HotSpotTypeDataBase.java:369)
        at sun.jvm.hotspot.HotSpotTypeDataBase.readVMTypes(HotSpotTypeDataBase.java:102)
        at sun.jvm.hotspot.HotSpotTypeDataBase.<init>(HotSpotTypeDataBase.java:85)
        at sun.jvm.hotspot.bugspot.BugSpotAgent.setupVM(BugSpotAgent.java:568)
        at sun.jvm.hotspot.bugspot.BugSpotAgent.go(BugSpotAgent.java:494)
        at sun.jvm.hotspot.bugspot.BugSpotAgent.attach(BugSpotAgent.java:332)
        at sun.jvm.hotspot.tools.Tool.start(Tool.java:163)
        at sun.jvm.hotspot.tools.HeapDumper.main(HeapDumper.java:77)
        at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
        at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
        at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
        at java.lang.reflect.Method.invoke(Method.java:597)
        at sun.tools.jmap.JMap.runTool(JMap.java:179)
        at sun.tools.jmap.JMap.main(JMap.java:110)
Debugger attached successfully.

何が問題になる可能性がありますか? プロセスを再起動せずに解決できますか(再起動するとバグが消える可能性があるため、回避したい)。

4

3 に答える 3

1

何が問題になる可能性がありますか? プロセスを再起動せずに解決できますか(再起動するとバグが消える可能性があるため、回避したい)。

明白なことを述べるリスクがあります...

開かれている接続が多すぎるためにデバッガーに接続できない場合、それはおそらく見つけようとしているバグの根本にもあります。

OS レベルのユーティリティを使用して、プロセスが現在開いているファイル/ソケットなどを調べてみてください。どこから探すべきかを教えてくれる手がかりをあなたが与えてくれること。それでも不十分な場合は、ファイル/ソケットが開かれているすべての場所をコードベースで検索し、それらを調べて、ファイル/ソケットtry / finally常に閉じる囲みがあることを確認してください。

于 2010-08-15T08:58:23.210 に答える
0

Sun 6 JDKのvisualvmを使用して接続できますか?これは別の方法を使用し、多くのことを学ぶことができます-それで十分かもしれません-しかしデバッガーではありません。

于 2010-08-15T08:42:11.813 に答える