JVM锁优化

简介: JVM锁优化

JVM之锁优化 锁总结

  • Java对于锁的优化:归根结底是权衡操作系统中用户态、核心态切换的资源损耗与CPU空转资源损耗
  • 偏向锁适用于单线程无竞争的情况
  • 轻量级锁适用于存在线程竞争,但是不激烈的情况
  • 重量级锁适用于竞争激烈的情况(当CAS的损耗>操作系统用户态、核心态切换的损耗时,转变为重量级锁)

自旋锁

  • 为什么引入自旋锁?
  • 在实现互斥同步时,我们需要借助操作系统;在这个过程中,可能会存在用户态到和核心态之间的切换(这个切换十分消耗资源)
  • 引入自旋锁:我们默认当前线程阻塞的时间很短,当前线程可以很快获取锁;而不要依赖操作系统,让当前线程处于一个循环的状态(自旋)
  • 目的:通过自旋来降低操作系统状态转换、线程切换的开销
  • 自旋锁存在问题:
  • 假设当前线程无法短时间获取处理器执行权,则线程会处于一个持久的空转状态(自旋);这个空转所造成的开销可能导致大于线程切换的开销

自适应锁

  • 自适应锁:
  • 解决自旋时间过长、过度消耗资源的问题
  • 通过上一次自旋的时长来决定下一次自旋的时长(如果上一次自旋过长,则认为我将难以获取锁;延长我自旋的时间,甚至放弃自旋;若上一次自旋时间很短,则认为我也很容易获取锁,降低自旋的时间)
  • 锁消除:
  • 指JVM在对代码进行编译时,对一些代码要求同步,但是经JVM检测不可能发生数据竞争,进而消除锁
  • 如代码块:
  • StringBuffer类的每一个方法都需要synchronized修饰,但是stringBuffer永远无法逃逸出sysTest方法作用域,故而不会发生任何的数据竞争
  • 锁粗化:
  • 指需要对一个对象进行重复加锁、释放锁;这是性能损耗也很高,锁粗化为第一个操作开始前以及最后一个操作执行后;
  • 如代码块:
  • 对象MarkWord布局图:
  • 偏向锁
  • 只比较当前线程的ID与被锁对象的对象头MarkWord中的线程ID;不进行CAS操作
  • 当锁对象第一次被线程获取时,ThreadID写入锁对象的MarkWord,修改标志位为01,偏向模式为1
  • 当ThreadID与对象头ThreadID不一致时(发生竞争时);修改标志位为01或00、偏向模式为0(撤销偏向锁,升级为轻量级锁)
  • 轻量级锁
  • 通过CAS操作,减少重量级锁的使用,进而减少重量级锁所带来的性能损耗
  • 1.当锁的标置位为01时,当前线程栈会新建锁记录(Lock Record)用以记录被锁对象的MarkWord
  • 2.而后会通过CAS将对象头的MarkWord更新为指向线程栈的Lock Record的指针;
  • 3.如果更新成功,也就代表了当前线程拥有了锁,同时修改标志位为00
  • 4.如果更新失败,则说明至少存在一个线程与当前线程竞争
  • 4.1 再次比较MarkWord指针是否指向当前线程栈帧;若指向当前栈帧,则执行同步代码块
  • 5.重复执行若干次轻量级锁CAS操作后,若对象头的MarkWord指针还是未指向当前线程栈,则锁升级为重量级锁(轻量级锁->重量级锁)
  • 重量级锁
  • 在轻量级锁进行若干次CAS操作后,被锁对象的MarkWord指针依然没有指向当前线程栈,则升级为重量级锁;
  • 标志位修改为10,此时被锁对象的MarkWord指向重量级锁(互斥量,依赖于操作系统);而后所有的等待线程需进入block状态
  • 锁升级流程图(CV大法):
目录
相关文章
|
1月前
|
监控 算法 Java
Java虚拟机(JVM)垃圾回收机制深度剖析与优化策略####
本文作为一篇技术性文章,深入探讨了Java虚拟机(JVM)中垃圾回收的工作原理,详细分析了标记-清除、复制算法、标记-压缩及分代收集等主流垃圾回收算法的特点和适用场景。通过实际案例,展示了不同GC(Garbage Collector)算法在应用中的表现差异,并针对大型应用提出了一系列优化策略,包括选择合适的GC算法、调整堆内存大小、并行与并发GC调优等,旨在帮助开发者更好地理解和优化Java应用的性能。 ####
40 0
|
3月前
|
存储 安全 Java
jvm 锁的 膨胀过程?锁内存怎么变化的
【10月更文挑战第3天】在Java虚拟机(JVM)中,`synchronized`关键字用于实现同步,确保多个线程在访问共享资源时的一致性和线程安全。JVM对`synchronized`进行了优化,以适应不同的竞争场景,这种优化主要体现在锁的膨胀过程,即从偏向锁到轻量级锁,再到重量级锁的转变。下面我们将详细介绍这一过程以及锁在内存中的变化。
48 4
|
22天前
|
NoSQL Java Redis
秒杀抢购场景下实战JVM级别锁与分布式锁
在电商系统中,秒杀抢购活动是一种常见的营销手段。它通过设定极低的价格和有限的商品数量,吸引大量用户在特定时间点抢购,从而迅速增加销量、提升品牌曝光度和用户活跃度。然而,这种活动也对系统的性能和稳定性提出了极高的要求。特别是在秒杀开始的瞬间,系统需要处理海量的并发请求,同时确保数据的准确性和一致性。 为了解决这些问题,系统开发者们引入了锁机制。锁机制是一种用于控制对共享资源的并发访问的技术,它能够确保在同一时间只有一个进程或线程能够操作某个资源,从而避免数据不一致或冲突。在秒杀抢购场景下,锁机制显得尤为重要,它能够保证商品库存的扣减操作是原子性的,避免出现超卖或数据不一致的情况。
51 10
|
1月前
|
存储 监控 算法
Java虚拟机(JVM)垃圾回收机制深度解析与优化策略####
本文旨在深入探讨Java虚拟机(JVM)的垃圾回收机制,揭示其工作原理、常见算法及参数调优方法。通过剖析垃圾回收的生命周期、内存区域划分以及GC日志分析,为开发者提供一套实用的JVM垃圾回收优化指南,助力提升Java应用的性能与稳定性。 ####
|
2月前
|
监控 算法 Java
Java虚拟机垃圾回收机制深度剖析与优化策略####
【10月更文挑战第21天】 本文旨在深入探讨Java虚拟机(JVM)中的垃圾回收机制,揭示其工作原理、常见算法及参数调优技巧。通过案例分析,展示如何根据应用特性调整GC策略,以提升Java应用的性能和稳定性,为开发者提供实战中的优化指南。 ####
46 5
|
2月前
|
监控 Java 开发者
Java虚拟机(JVM)深度优化指南####
本文深入探讨了Java虚拟机(JVM)的工作原理及其性能优化策略,旨在帮助开发者通过理解JVM的内部机制来提升Java应用的运行效率。不同于传统的技术教程,本文采用案例分析与实战技巧相结合的方式,为读者揭示JVM调优的艺术。 ####
58 8
|
2月前
|
存储 IDE Java
实战优化公司线上系统JVM:从基础到高级
【11月更文挑战第28天】Java虚拟机(JVM)是Java语言的核心组件,它使得Java程序能够实现“一次编写,到处运行”的跨平台特性。在现代应用程序中,JVM的性能和稳定性直接影响到系统的整体表现。本文将深入探讨JVM的基础知识、基本特点、定义、发展历史、主要概念、调试工具、内存管理、垃圾回收、性能调优等方面,并提供一个实际的问题demo,使用IntelliJ IDEA工具进行调试演示。
42 0
|
3月前
|
Arthas 监控 Java
JVM知识体系学习七:了解JVM常用命令行参数、GC日志详解、调优三大方面(JVM规划和预调优、优化JVM环境、JVM运行出现的各种问题)、Arthas
这篇文章全面介绍了JVM的命令行参数、GC日志分析以及性能调优的各个方面,包括监控工具使用和实际案例分析。
87 3
|
3月前
|
存储 算法 Java
深入理解Java虚拟机(JVM)及其优化策略
【10月更文挑战第10天】深入理解Java虚拟机(JVM)及其优化策略
58 1
|
3月前
|
存储 安全 Java
JVM锁的膨胀过程与锁内存变化解析
在Java虚拟机(JVM)中,锁机制是确保多线程环境下数据一致性和线程安全的重要手段。随着线程对共享资源的竞争程度不同,JVM中的锁会经历从低级到高级的膨胀过程,以适应不同的并发场景。本文将深入探讨JVM锁的膨胀过程,以及锁在内存中的变化。
58 1