草庐IT

jvm-bytecode

全部标签

JVM致命错误日志详解

目录文件描述文件位置文件头错误信息记录JVM运行信息崩溃原因错误信息线程描述线程信息信号信息计数器信息机器指令内存映射信息线程堆栈其他信息进程描述线程列表虚拟机状态互斥锁/管程堆概览卡表和本地代码缓存编译事件GC事件逆向优化事件内部错误事件内存信息虚拟机参数和环境变量信号处理器系统信息操作系统内存信息CPU信息总结这篇文章是我之前总结的一篇文章,因为整理博客的原因,原有博客已经注销,但这篇文章对一些读者很有用,所以现在新瓶装旧酒重新整理回来分享给大家。最近一段时间生产环境频繁出问题,每次都会生成一个hs_err_pid*.log文件,因为工作内容的原因,在此之前并没有了解过相关内容,趁此机会学

【技术积累】Java中的JVM【一】

什么是JVMJVM英文全称为JavaVirtualMachine,中文意为Java虚拟机。JVM是一种能够执行Java语言编写的程序的虚拟机器,它首次作为Java语言的一部分,后来又被移植到了许多平台上。JVM可以执行Java字节码,即Java源代码经过编译后生成的二进制中间代码。JVM根据字节码指令来执行程序,这就使得Java程序跨平台,在不同的操作系统上运行时不需要修改源代码。JVM本身也是跨平台的,因为JVM实际上就是使用底层机器代码实现的软件层,因此只需安装相应平台的JVM即可。JVM的主要组件包括:类加载器:负责将.class二进制文件转换为在运行时可以被JVM识别的类对象。运行时数

深入分析JVM执行引擎

程序和机器沟通的桥梁一、闲聊相信很多朋友在出国旅游,或者与外国友人沟通的过程中,都会遇到语言不通的烦恼。这时候我们就需要掌握对应的外语或者拥有一部翻译机。而笔者只会中文,所以需要借助一部翻译器才能与不懂中文的外国友人交流。咱们的执行引擎就类似于这部“翻译机”。二、概述执行引擎的作用就是将字节码指令解释或者编译为对应平台上的本地机器指令。简单来说,执行引擎充当了将高级语言翻译为机器语言的翻译者。对于Hotspot虚拟机,执行引擎中包含两部分:解释器和JIT编译器(即时编译器)。下图是执行引擎的原理:三、解释器解释器所承担的角色就是一个运行时翻译者,将字节码文件中的内容翻译为对应平台的本地机器码指

JVM中的锁优化

锁优化Jvm在加锁的过程中,会采用自旋、自适应、锁消除、锁粗化等优化手段来提升代码执行效率。什么是锁升级,降级?锁的4中状态:无锁状态、偏向锁状态、轻量级锁状态、重量级锁状态(级别从低到高)。所谓的锁升级、降级,就是JVM优化synchronized运行的机制,当JVM监测到不同的竞争状况是,会自动切换到不同的锁实现。这种切换就是锁的升级、降级。锁升级偏向锁因为经过大量的研究发现,大多数时候是不存在锁竞争的,常常是一个线程多次获得同一个锁,因此如果每次都要竞争锁会增大很多没有必要付出的代价,为了降低获取锁的代价,才引入的偏向锁。在程序的一开始,处于无锁状态。紧接着,有一个线程申请锁,此时通过C

JVM——VisualVM使用说明

概述VisualVM是一款免费的\集成了多个JDK命令行工具的可视化工具,它能为您提供强大的分析能力,对Java应用程序做性能分析和调优。VisualVM提供了包括生成和分析海量数据、跟踪内存泄漏、监控垃圾回收器、执行内存和CPU分析,同时它还支持在MBeans上进行浏览和操作等功能。VisualVM下载地址:http://visualvm.github.io/download.html相比JConsole,感觉功能更强大,且可集成各类插件,使其更强大。Jconsole算是VisualVM的子集吧。另外VisualVM也有JConsole的插件;相比Arthas,它最大的特点肯定就是图形化了。

一文深度讲解JVM 内存分析工具 MAT及实践(建议收藏)

1.前言熟练掌握MAT是Java高手的必备能力,但实践时大家往往需面对众多功能,眼花缭乱不知如何下手,小编也没有找到一篇完善的教学素材,所以整理本文帮大家系统掌握MAT分析工具。本文详细讲解MAT众多内存分析工具功能,这些功能组合使用异常强大,熟练使用几乎可以解决所有的堆内存离线分析的问题。我们将功能划分为4类:内存分布详情、对象间依赖、对象状态详情、按条件检索。每大类有多个功能点,本文会逐一讲解各功能的场景及用法。此外,添加了原创或引用案例加强理解和掌握。如图所示:​编辑切换为居中添加图片注释,不超过140字(可选)为减少对眼花缭乱的菜单的迷茫,可以通过下图先整体熟悉下各功能使用入口,后续都

【编程实践】JVM内存管理的核心数据结构和算法思想&代码示例说明

【编程实践】JVM内存管理的核心数据结构和算法思想&代码示例说明文章目录【编程实践】JVM内存管理的核心数据结构和算法思想&代码示例说明前言堆内存管理堆内存年轻一代老一辈非堆内存堆元空间预留空间代码缓存YoungGenerationOldGenerationPermGenClassMetadata数据结构(仅供参考)JVM中Metaspace的数据结构栈内存管理总

JVM成神路终章:深入死磕Java虚拟机序列总纲

先附上之前画的JVM全景架构图。  时光荏苒,时间一点一点地流逝,不知不觉中半载光阴便稍纵即逝,犹如白驹过隙。继之前的《并发编程系列》后,JVM系列的文章至此也画上了句号,与《并发编程》系列相同,列出总纲目录方便诸位翻阅。  在刚接触Java虚拟机时,JVM的一些常识认知,HotSpot虚拟机的“前世今生”以及Java虚拟机发展史上的一些趣事,作为了《JVM系列》的开篇:(一)《JVM成神路之初识虚拟机-探寻Java虚拟机的前世今生之秘》  紧接着,作为Java代码入口的类加载子系统出现在了我们的视野中,本篇中对于虚拟机的类加载机制,从类加载过程、类加载器、双亲委派模型、自定义类加载器以及打破

JVM性能分析

JIT在谈到Java的编译机制的时候,其实应该按时期,分为两个阶段。一个是javac指令将Java源码变为Java字节码的静态编译过程。另一个是Java字节码编译为本地机器码的过程,并且因为这个过程是在程序运行时期完成的所以称之为即时编译(JIT),下面我们讨论的编译也都是指“即时编译”过程。解释器java作为一种跨平台的语言实现了一次编译到处运行的特性,这也就决定了它编译出来的不是机器码而是特定的字节码。解释器(各平台不同)就是将字节码解释为机器指令,调用操作系统来完成程序的执行。编译器解释器虽然实现了跨平台的特性,但是解释执行的效率是很低的,是以牺牲性能为代价来换取的跨平台特性。所以JVM

JAVA:java.net.BindException: 地址已被使用: JVM_Bind

这个问题在这里已经有了答案:HowdoIresolvethe"java.net.BindException:Addressalreadyinuse:JVM_Bind"error?(22个答案)关闭5年前。我已经写了这两个类,一个用于客户端,另一个用于服务器。当我同时运行它们时,出现以下错误:java.net.BindException:Addressalreadyinuse:JVM_Bind...问题是什么?我还使用TCPview软件,只有两个java.exe使用相同的端口。这两个java.exe进程属于应用程序。代码如下:服务器代码/****@authorcasinoroyal*/p