Java分布式锁

Java分布式锁Java分布式锁我的理解应该叫集群锁或者跨实例锁锁的作用是在多线程情况下,控制线程同步访问变量,执行代码块、方法,例如synchronized,在单个jvm进程中,这样是奏效的。但是在分布式环境中,单个服务往往都是要部署多台实例的,在有多个jvm进程的集群里,synchronized就达不到我们的要求了。synchronized只能控制当前jvm进程中的线程,对于其它jvm进程中的线程,它无能为力。也就是说有可能一个jvm中的线程是同步执行的,在此过程中,或许会有集群里其它jvm的线程执行到

大家好,又见面了,我是你们的朋友全栈君。

Java分布式锁

我的理解应该叫集群锁或者跨实例锁

锁的作用是在多线程情况下,控制线程同步访问变量,执行代码块、方法,
例如synchronized,在单个jvm进程中,这样是奏效的。

但是在分布式环境中,单个服务往往都是要部署多台实例的,
在有多个jvm进程的集群里,synchronized就达不到我们的要求了。

synchronized只能控制当前jvm进程中的线程,对于其它jvm进程中的线程,它无能为力。
也就是说有可能一个jvm中的线程是同步执行的,在此过程中,
或许会有集群里其它jvm的线程执行到这儿,它不会被阻塞,那这就不是同步了。

对synchronized不太了解的话可以看下这里:
对于Java中synchronized关键字的简单理解

为了应对这种场景,分布式锁就出现了。

基于数据库的分布式锁

实现方式是:在数据库中创建一张表,包含变量名、方法名、服务器IP+线程ID等信息,
变量名、方法名字段上加有唯一约束,
想要访问某个变量或执行某个方法,就往这张表添加数据,
添加成功则获取锁,若添加失败则根据当前服务器+线程和变量名、方法名查询数据,
如果存在对应记录,也获取锁,不存在则需要重试获取锁,执行完成后立即删除对应记录。

线程ID是为了实现锁的可重入性,什么是可重入:
Java多线程-01.ReentrantLock、ReadWriteLock

依赖数据库需要一定的资源开销,性能问题需要考虑。

基于Redis的分布式锁

基于Redis的优点:
1、Redis有着很高的性能;
2、Redis的方法对于实现分布式锁有着较好的支持;

实现方式是:
获取锁的时候,使用setnx加锁,
setnx:当且仅当key不存在时,set一个值为value的key,返回1,
若key存在,不做任何操作,返回0。
key我们取变量名、方法名,value存当前服务器IP+线程ID。
可以设置一个超时时间,超时自动释放锁,
执行完成后立即删除对应的key。


不当之处,请与指正。

参考文章:

刘清政的博客什么是分布式锁?实现分布式锁的三种方式

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/132386.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

  • 【网盘搭建】使用Rclone挂载Google Drive扩容服务器存储,实现网盘无限容量[通俗易懂]

    【网盘搭建】使用Rclone挂载Google Drive扩容服务器存储,实现网盘无限容量[通俗易懂]一,前言1,Rclone是什么Rclone是一个开源的命令行程序,用于管理云存储上的文件。它是云供应商Web存储界面的功能丰富的替代方案。超过50种云存储产品支持Rclone,包括S3对象存储,GoogleDrive,OneDrive等业务和消费者文件存储服务以及标准传输协议。2,它能用来干嘛可以备份(和加密)文件到云存储。从云存储还原(和解密)文件。将云数据镜像到其他云服务或本地。将数据迁移到云,或在云存储供应商之间迁移。将多个加密的,缓存的或多样化的云存储作为磁盘挂载。3,项目地址Gith

  • 如何利用matlab做BP神经网络分析(利用matlab神经网络工具箱)[通俗易懂]

    如何利用matlab做BP神经网络分析(利用matlab神经网络工具箱)[通俗易懂]最近一段时间在研究如何利用预测其销量个数,在网上搜索了一下,发现了很多模型来预测,比如利用回归模型、时间序列模型,GM(1,1)模型,可是自己在结合实际的工作内容,发现这几种模型预测的精度不是很高,于是再在网上进行搜索,发现神经网络模型可以来预测,并且有很多是结合时间序列或者SVM(支持向量机)等组合模型来进行预测,本文结合实际数据,选取了常用的BP神经网络算法,其算法原理,因网上一大堆,所以…

  • windows下php7.1安装redis扩展以及redis测试使用全过程

    windows下php7.1安装redis扩展以及redis测试使用全过程

    2021年10月21日
  • [Cubieboard] 镜像资源汇总

    [Cubieboard] 镜像资源汇总

  • matlab插值拟合案例,matlab插值与拟合

    matlab插值拟合案例,matlab插值与拟合《matlab插值与拟合》由会员分享,可在线阅读,更多相关《matlab插值与拟合(10页珍藏版)》请在人人文库网上搜索。1、实验2插值与拟合实验内容:1.三种插值方法2用Matlab计算插值3拟合的基本原理4用Matlab拟合曲线实验目的:掌握插值与拟合方法一、概念的引入1.插值与拟合在现实生活中的应用l机械制造:汽车外观设计l采样数据的重新建构:电脑游戏中场景的显示,…

  • getjson跨域

    getjson跨域

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号