草庐IT

jvm-default

全部标签

java - 从 JVM 上的栈帧获取局部变量

有没有什么方法可以在不使用调试器的情况下在JVM的当前范围内获取局部变量的映射或其他数据结构?即获取当前栈帧的locals?我知道有堆栈跟踪对象,但StackTraceElement无法访问任何状态。它只是告诉您在何处调用了哪个方法,而不是其中的内容。 最佳答案 变量名可以包含在类文件中以帮助调试器,但javac默认情况下不这样做。它需要-g:vars选项。如果它存在,程序可以使用像ASM这样的字节码工程库。访问局部变量名称和范围。同时thisquestion措辞不佳,我认为它是重复的,其答案可能与您的问题有关。我要补充一点,如果您

java - 我可以从实时 JVM 转储当前线程堆栈变量吗?

我需要查看2个死锁线程的堆栈以分析情况。JVM现在是实时的,数据也在那里,但我需要某种工具来从进程中提取它。我只关心String类型的堆栈中的6个变量。非常感谢任何想法。JVM版本6_35,它是一个linux,启用了JMX,但我没有profiler/在其上配置的调试器连接。很难重现。 最佳答案 我发现了一个使用堆转储查看器的小技巧(在本例中是YourKit,但其他人也可以)。基本上你枚举Thread类的所有实例,然后你通过名称找到你想要的线程并打开它。堆栈变量标记为,如下所示:并不是所有的变量都在这里,但是所有作为参数传递给方法的变

java - JVM 崩溃并出现错误 ='Cannot allocate memory' (errno=12)

我的代码因此错误消息而崩溃Executing"/usr/bin/javacom.utils.BotFilter"OpenJDK64-BitServerVMwarning:INFO:os::commit_memory(0x0000000357c80000,2712666112,0)failed;error='Cannotallocatememory'(errno=12)ThereisinsufficientmemoryfortheJavaRuntimeEnvironmenttocontinue.Nativememoryallocation(malloc)failedtoallocate2

java.lang.UnsatisfiedLinkError : Cannot load 64-bit SWT libraries on 32-bit JVM in Windows x86 machine 错误

我刚刚开始使用swt(windowsx86_x64兼容版本)。当我在Eclipse中运行示例代码片段时,出现以下错误...Exceptioninthread"main"java.lang.UnsatisfiedLinkError:Cannotload64-bitSWTlibrarieson32-bitJVMatorg.eclipse.swt.internal.Library.loadLibrary(UnknownSource)atorg.eclipse.swt.internal.Library.loadLibrary(UnknownSource)atorg.eclipse.swt.in

java - 我可以强制生成 JVM 崩溃日志文件吗?

JVM崩溃的日志文件包含各种对调试有用的信息,例如加载的共享库和完整的环境。我可以强制JVM以编程方式生成其中之一吗?通过执行崩溃它的代码或其他方式?或者以其他方式访问相同的信息? 最佳答案 您可以尝试抛出OutOfMemoryError并添加-XX:+HeapDumpOnOutOfMemoryErrorjvm参数。这是1.6中的新工具,也是McDowell建议的其他工具。http://blogs.oracle.com/watt/resource/jvm-options-list.html

java - 以编程方式填充 JVM 永久代 (PermGen) 内存区域

我需要测试我开发的一些JMX监控脚本,特别是我想验证我对PermGen区域的监控是否正常工作。因此,为了对此进行测试,我希望能够运行一些代码来加载大量类,以便使用PermGen。我目前的计划是编写一个脚本来生成prefix(1..n).java编译它们,然后按提示运行:for(inti=1;i是否有更优雅的解决方案来实现这一目标? 最佳答案 好的,看来String.intern()可以解决问题。这是我发现的一个实现。也归功于Gareth:publicstaticvoidmain(String[]args)throwsClassNot

java - 如何分析JVM崩溃文件hs_err_pidXYZ.log

在Eclipse和Tomcat(wtp)中处理webapp时,tomcat崩溃并创建一个文件:hs_err_pid20216.log我尝试使用eclipseMAT来分析文件,但MAT无法将文件识别为它可以处理的文件,我也尝试了DAT,结果是一样的。它不会显示在打开的文件对话框中。这是什么类型的文件?我应该用什么来分析它?我是否必须更改此文件以便这些工具能够解析它。日志文件以GitHubgist形式提供。更新:有关如何处理hs_err_pidXYZ.log文件的更多信息,请参阅@DanCruz的回复。出于好奇,崩溃的原因是jackson被循环关系(双向一​​对多)弄糊涂了,但这是另一个故

java - JVM上的内存分配是无锁的吗

当你在Java中做一个newObject()时,jvm是使用无锁算法分配内存还是需要加锁?在这种情况下,我指的JVM是HotspotVM。据我所知,它只需要递增一个指针即可超快地分配内存。但是在多线程的情况下,这个增量是否需要加锁或者CAS? 最佳答案 如前所述,默认是使用tlab。thisglossary中描述了行为如下TLABThread-localallocationbuffer.Usedtoallocateheapspacequicklywithoutsynchronization.Compiledcodehasa"fast

java - Maven - 使用 JDK 7 为 JVM 5 编译

我已经尝试让它工作了一段时间,但还没有成功。我想用指向JDK7的JAVA_HOME运行,但我想为JVM5编译一个项目。我已经通读了documentation,我找到了similarposts在SO上,但它们似乎都不适用于我的设置。我首先尝试仅设置target和source但出现错误:org.apache.maven.pluginsmaven-compiler-plugin1.51.5[ClassName]isnotabstractanddoesnotoverrideabstractmethodgetParentLogger()inCommonDataSource据我所知,该类已在JDK

java - 如何调整 jvm 使其崩溃而不是英勇地 GC 直到 100% CPU 利用率?

我们有一个JVM进程,它很少将CPU占用100%,看起来(根据visualgc)堆几乎耗尽。我们的假设是该进程正在英勇地进行GC,导致CPU峰值,这会影响整个系统的整体健康状况(由其他JVM执行不同的事情组成)。这个过程并不关键,可以重新开始。有没有一种方法可以通过启动它的命令行来调整JVM,使其落在自己的剑上,而不是继续进行GC并导致整个盒子受到影响?值得注意的是,我们没有收到OOMException,因此堆并没有完全耗尽,但我们认为只是勉强没有耗尽。或者,一些东西可以让我们了解JVM中的什么实际上以确认/否定我们的GC假设的方式使用CPU? 最佳答案