13518219792

建站动态

根据您的个性需求进行定制 先人一步 抢占小程序红利时代

从Java锁到分布式锁

从 Java 锁到分布式锁

作者:程序员小航 2021-11-26 06:43:19

开发

后端

分布式 在并发编程中常用到 synchronized 以及 ReentrantLock 锁,在业务开发过程中也可能会用到分布式锁,分布式锁常用框架的就是基于 Redis 实现的分布式锁框架 Redisson 和 基于 Zookeeper 实现的分布式锁框架 Curator。当然,也有其他的锁实现方式,在这里不做介绍。

成都创新互联在网站设计、网站制作、手机APP定制开发、网站运营等方面均有出色的表现,凭借多年丰富的经验,我们会仔细了解各客户的需求而做出多方面的分析、设计、整合,为客户设计出具风格及创意性的商业解决方案,我们更提供一系列网络营销推广,网站制作和网站推广的服务,以推动各中小企业全面信息化,并利用创新技术帮助各行业提升企业形象和运营效率。

前言

在并发编程中常用到 synchronized 以及 ReentrantLock 锁,在业务开发过程中也可能会用到分布式锁,分布式锁常用框架的就是基于 Redis 实现的分布式锁框架 Redisson 和 基于 Zookeeper 实现的分布式锁框架 Curator。当然,也有其他的锁实现方式,在这里不做介绍。

本文主要是在学习 Java 锁以及分布式锁的源码后,做出的归纳总结。

1锁的最基本要素

为什么要使用锁?

关于为什么要使用锁这个问题,答案显而易见:“为了避免多线程并发冲突”。

在多线程中对公共数据的修改,必须要保证只有线程在进行操作。这里的公共数据可以是公共变量,也可以是数据库中的一行数据。

锁的基本要素

知道为什么要加锁之后,就可以得出加锁的基本要素:

简单来说应该就是这些要素,遗漏之处,欢迎补充。

2加锁标志

加锁标志,就是需要一个标志来表示是否加锁成功,并且这个加锁标志要保证原子性。

3锁持有者

4锁重入

当获得锁的线程再次尝试获取锁的时候,保证需要计数。

5锁等待

  1. 刚开始是无锁的
  2. 偏向锁:一段同步代码一直被一个线程访问,这个线程自动获取锁,大多数都是由同一个线程获取锁,这就会出现偏向锁。目的是只有一个线程执行同步代码块时提高性能,JDK 6 后在 JVM 中默认开启。对象头标志位(01-无锁) 是否偏向锁标志(1-是偏向锁)
  3. 轻量级锁:锁是偏向锁时,被其他线程访问,偏向锁就升级为轻量级锁,其他线程通过自旋形式尝试获取锁 对象头标志位 00
  4. 重量级锁:只有一个线程等待,该线程是在自旋等待获取锁。当自旋一定次数或者一个持有锁一个自旋时来了第三个线程,就会升级为重量级锁。对象头标志位 10

6锁释放

7总结

本文从多个角度总结分析了锁和分布式锁的基本要素,同样基于 MySQL 等数据库的锁可以参考实现。

 本文转载自微信公众号「程序员小航」,可以通过以下二维码关注。转载本文请联系程序员小航公众号。


当前文章:从Java锁到分布式锁
网站路径:http://cdbrznjsb.com/article/coscegp.html

其他资讯

让你的专属顾问为你服务