自定义博客皮肤VIP专享

*博客头图:

格式为PNG、JPG,宽度*高度大于1920*100像素,不超过2MB,主视觉建议放在右侧,请参照线上博客头图

请上传大于1920*100像素的图片!

博客底图:

图片格式为PNG、JPG,不超过1MB,可上下左右平铺至整个背景

栏目图:

图片格式为PNG、JPG,图片宽度*高度为300*38像素,不超过0.5MB

主标题颜色:

RGB颜色,例如:#AFAFAF

Hover:

RGB颜色,例如:#AFAFAF

副标题颜色:

RGB颜色,例如:#AFAFAF

自定义博客皮肤

-+
  • 博客(15)
  • 收藏
  • 关注

原创 方法调用的底层实现

方法调用的字节码指令关于方法的调用,Java 字节码 共提供了 5 个指令,来调用不同类型的方法:invokestatic 用来调用静态方法;invokespecial 用于调用私有实例方法、构造器及 super 关键字等;invokevirtual 用于调用非私有实例方法,比如 public 和 protected,大多数方法调用属于这一种;invokeinterface 和上面这条指令类似,不过作用于接口类;invokedynamic 用于调用动态方法。以上字节码可以通过代码实现再用jcl

2021-03-17 11:53:12 164

原创 直接内存泄漏与JVM源码分析

直接内存(堆外内存)直接内存(堆外内存)指的是 Java 应用程序通过直接方式从操作系统中申请的内存。这个差别与之前的堆、栈、方法区,那些内存都是经过了虚拟化。所以严格来说,这里是指直接内存。直接内存有哪些? 使用了 Java 的 Unsafe 类,做了一些本地内存的操作; Netty 的直接内存(Direct Memory),底层会调用操作系统的 malloc 函数。 JNI 或者 JNA 程序,直接操纵了本地内存,比如一些加密库;JNI 是 Java Native Interface

2020-08-25 22:44:23 342

原创 利用MAT工具分析内存泄漏

我们可以使用 jmap –histo 这种命令去分析哪些对象占据着我们的堆空间。但是那是比较容易分析的问题,如果是遇到内存情况比较复杂的情况,命令的方式是看不出来的,这个时候我们必须要借助一下工具。当然前提是通过 jmap 命令把整个堆内存的数据 dump 下来。包括jdk自带的内存分析工具VisualVM,分析的数据非常有限。MAT 简介MAT 工具是基于 Eclipse 平台开发的,本身是一个 Java 程序,是一款很好的内存分析工具,所以如果你的堆快照比较大的话,则需要一台内存比较大的分析机器,

2020-08-22 14:00:21 1001

原创 JVM调优与问题排查

JVM 调优分类调优是一个很大的概念,简单说就是把系统进行优化,但是站在系统的角度,我们一般把jvm条又分为三部分:1.JVM预调优2.调优JVM 运行环境(慢、卡顿等)3.解决JVM中的问题(OOM、CPU飙升等)调优中,现象最明显的是 OOM,因为有异常抛出,当然它也只是作为调优的一部分。预调优和优化运行环境估计很多人做的就是服务器重启而已。前一篇文章调优就是JVM内存结构调优的一种方式。JVM 预调优业务场景设定调优是要分场景的,所以一定要明显你调优项目的场景设定,像现在大家都是微服务

2020-08-18 10:54:08 1672

原创 JVM性能调优之内存调优与GC优化

JVM 性能调优之内存优化与 GC 优化JVM 调优是一个系统而又复杂的过程,但我们知道,在大多数情况下,我们基本不用去调整 JVM 内存分配,因为一些初始化的参数已经可以保证应用服务正常稳定地工作了。在应用服务的特定场景下,JVM 内存分配不合理带来的性能表现并不会像内存溢出问题这么突出。一般你没有深入到各项性能指标中去,是很难发现其中隐藏的性能损耗。压测工具 ABAb(ApacheBench) 测试工具是 Apache 提供的一款测试工具,具有简单易上手的特点,在测试 Web 服务时非常实用。

2020-08-14 15:20:50 928

原创 GC调优基础知识与工具

JDK 为我们提供的工具在windows上,我们安装jdk之后,jdk安装包的bin目录下自带很多exe文件。在 linux 中,一般自带了 OpenJdk, 一般情况下 JPS 等命令不能用,要么选择去安装 JPS 等插件,要么把 OpenJdk 卸载,去重新安装 Oracle 的 JDK,我推荐后者。标题命令行工具jps列出当前机器上正在运行的虚拟机进程,JPS 从操作系统的临时目录上去找(所以有一些信息可能显示不全)。类似于linux下的pid查询/** * @author *

2020-08-09 12:02:06 401

原创 虚拟机类加载机制

深入 JVM 即时编译器 JIT解释执行与 JITJava 程序在运行的时候,主要就是执行字节码指令,一般这些指令会按照顺序解释执行,这种就是解释执行,解释执行的方式是非常低效的,它需要把字节码先翻译成机器码,才能往下执行。另外,字节码是 Java 编译器做的一次初级优化,许多代码可以满足语法分析,其实还有很大的优化空间。所以,为了提高热点代码的执行效率,在运行时,虚拟机将会把这些代码编译成与本地平台相关的机器码,并进行各种层次的优化。完成这个任务的编译器,就称为即时编译器(Just In Time C

2020-08-05 10:43:45 154

原创 Class文件结构及字节码指令

JVM 的无关性与平台无关性是建立在操作系统上,虚拟机厂商提供了许多可以运行在各种不同平台的虚拟机,它们都可以载入和执行字节码,从而实现程序的“一次编写,到处运行”各种不同平台的虚拟机与所有平台都统一使用的程序存储格式——字节码(ByteCode)是构成平台无关性的基石,也是语言无关性的基础。Java 虚拟机不和包括 Java 在内的任何语言绑定,它只与“Class 文件”这种特定的二进制文件格式所关联,Class 文件中包含了 Java 虚拟机指令集和符号表以及若干其他辅助信息。Class 类文件

2020-08-03 11:42:29 755

原创 垃圾回收器及 HostSpot 的细节实现

并发标记与三色标记三色标记在三色标记法之前有一个算法叫 Mark-And-Sweep(标记清除)。这个算法会设置一个标志位来记录对象是否被使用。最开始所有的标记位都是 0,如果发现对象是可达的就会置为 1,一步步下去就会呈现一个类似树状的结果。等标记的步骤完成后,会将未被标记的对象统一清理,再次把所有的标记位设置成 0 方便下次清理。这个算法最大的问题是 GC 执行期间需要把整个程序完全暂停,不能异步进行 GC 操作。因为在不同阶段标记清扫法的标志位 0 和 1 有不同的含义,那么新增的对象无论标记为什

2020-08-01 09:04:58 642

原创 垃圾回收及回收器

垃圾回收基础知识什么是GC?Java 与 C++等语言最大的技术区别:自动化的垃圾回收机制(GC)如果某个对象到GC Roots间没有任何引用链相连,或者用图论的话来说就是从GC Roots到这个对象不可达时,则证明此对象是不可能再被使用的分代回收理论1、 绝大部分的对象都是朝生夕死。2、 熬过多次垃圾回收的对象就越难回收。根据以上两个理论,朝生夕死的对象放一个区域,难回收的对象放另外一个区域,这个就构成了 新生代和 老年代GC分类1、 新生代回收(Minor GC/Young GC)

2020-07-30 10:32:39 226

原创 JVM中的对象

JVM中的对象本文参考深入理解JAVA虚拟机第二版和第三版,如有问题,麻烦指出。JAVA创建对象,遇到一条new指令是如何执行的?虚拟机遇到一条 new 指令时,首先检查是否被类加载器加载,如果没有,那必须先执行相应的类加载过程。类加载就是把 class 加载到 JVM 的运行时数据区的过程。1 )检查加载首先检查这个指令的参数是否能在常量池中定位到一个类的符号引用( 符号引用 :符号引用以一组符号来描述所引用的目标 ),并且检查类是否已经被加载、解析和初始化过。2 )分配内存接下来虚拟

2020-07-22 13:01:46 132

原创 深入理解JVM内存结构

深入理解JVM内存结构(二)JVM 向操作系统申请内存:JVM 第一步就是通过配置参数或者默认配置参数向操作系统申请内存空间,根据内存大小找到具体的内存分配表,然后把内存段的起始地址和终止地址分配给 JVM,接下来 JVM 就进行内部分配。JVM 获得内存空间后,会根据配置参数分配堆、栈以及方法区的内存大小-Xms30m -Xmx30m -Xss1m -XX:MaxMetaspaceSize=30m类加载(类加载的细节后续章节会讲):这里主要是把 class 放入方法区、还有 class 中的静

2020-07-22 11:35:16 290

原创 JVM 基础知识

JVM 基础知识JVM 从编译到执行Java 程序的执行过程一个java程序,首先经过javac编译成.class文件,然后JVM 将其加载到方法区,执行引擎将会执行这些字节码。执行时,会翻译成操作系统相关的函数。JVM 作为 .class 文件的翻译存在,输入字节码,调用操作系统函数。过程如下:Java 文件->编译器>字节码->JVM->机器码JVM 全称 Java Virtual Machine,也就是我们耳熟能详的 Java 虚拟机。它能识别 .class 后缀的

2020-07-18 16:31:03 169

原创 linux笔记

1.1.1.1 虚拟机网络模式介绍1. 桥接模式相当于将虚拟机直接接入局域网中,这时会自己独占IP地址.可以与本机通过局域网通信.特点:所有的在局域网中的IP都可以访问虚拟机.2. NAT模式相当于在网络环境中会开辟一块全新的网络空间.只有主机能够访问.特点:NAT模式只有主机访问,其他人通过IP地址禁止访问.2.linux安装jdk我用的是xshell远程连接工具ssh+ipcd ../调转到根...

2018-07-06 20:28:31 111

原创 Nginx简介

    1. Nginx是一个高性能的http和反向代理服务器,也是一个IMAP/POP3/SMTP服务器,由老毛子发布其将源代码以类BSD许可证的形式发布,因它的稳定性、丰富的功能集、示例配置文件和低系统资源的消耗而闻名。     Nginx是一款轻量级的web服务器/反向代理服务器及电子邮件代理服务器主要特点:占有内存少,并发能力强。并发量:能够支持50000次的并发链接下载地址:http:/...

2018-07-06 19:42:48 245

空空如也

空空如也

TA创建的收藏夹 TA关注的收藏夹

TA关注的人

提示
确定要删除当前文章?
取消 删除