java分布式锁分布式锁
java分布式&锁&分布式锁
锁
- 锁的作用:有限资源的情况下,控制同一时间段,只有某些线程(用户/服务器)能访问到资源。

- 锁在java中的实现:
- synchronized关键字
- 并发包的类
- 缺点:只对单个的jvm有效

分布式锁
- 为什么实现分布式锁
- 有限资源的情况下,控制同一段时间只有某些用户/服务器才能访问到资源
- 单个锁只对单个jvm有效
- 分布锁实现(核心思想,先来server把数据改成自己的标识,后来的人发现标识已经存在就等待)
- 抢锁机制 ==> 同一时间只有一个服务器能抢到资源 ==>
- Mysql数据库实现,数据库中有一个字段标识锁,哪个服务器先到达数据库,就将此标识改为自己服务器的值,下一个服务器查到达查看不为空就等待,知道此上一个服务器用完,将标识位改为空时,方可用。
- 查select(控制只有一个服务器在查)(1.select for update 行级锁,2.乐观锁)
- 改update
- redis实现,存标识。读写速度快,支持setnx,lua脚本实现
- 原理:使用redis的setnx方法保证原子性质
setnx:set if not exist如果不存在,则设置,只有设置成功才会返回true,否则返回false

- 注意1: 用完锁之后要释放,防止在释放之前服务器出现意外,因此要设置过期时间
- 注意2:如果方法执行时间过长,锁提前过期,出现多个服务器同时执行。=> 续期(redisson中提供续期机制,原理:监听当前线程,默认过期时间是30s,每10s续期一次(补充到30s),如果线程挂了,则不会续期,如果debug模式也会被当成服务器宕机)。
- 注意3:连锁效应:释放了其他server的锁 .=> 判断如果不是我的锁就不释放
- 注意4:释放锁的时候,有可能先判断出是自己的锁,但是这时候锁过期了,会释放其他服务器/用户的锁 => 判断和释放的时候不允许其他任何的方法进入,redis原子性操作。配合redis+lua脚本。
- 原理:使用redis的setnx方法保证原子性质
- Mysql数据库实现,数据库中有一个字段标识锁,哪个服务器先到达数据库,就将此标识改为自己服务器的值,下一个服务器查到达查看不为空就等待,知道此上一个服务器用完,将标识位改为空时,方可用。
- Zookeeper实现
- 抢锁机制 ==> 同一时间只有一个服务器能抢到资源 ==>
控制定时任务的执行(在同一时间只有一个服务器能执行)
-
原因:
- 浪费资源,假设有1000台服务器同时工作
- 脏数据

-
实现方式
-
分离定时任务,把控制定时任务从主程序中拆开(成本太大)

-
配置,写死配置,每个服务器都执行定时任务,但是只有ip符合配置的才真实执行业务逻辑,其他的直接返回。

-
☆动态配置,这个配置是可以轻松的跟新的,把配置写到数据库,Redis,配置中心(Nacos,Apollo,spring Cloud config)(问题:如果服务器数据太多,ip不可控制)

-
分布式锁【只有抢到锁的服务器才能执行定时任务】

-
Reddisson实现分布式锁
- Redisson:是一个java操作Redis的客户端,提供了大量的分布式数据集来简化对Redis的操作和使用,可以让开发者像使用本地集合一样使用Redis,完全感觉不到Redis的存在。
redisson官网:redisson - Redisson使用方法
- 支持springboot整合Rdisson,写配置,默认整合客户端。(版本迭代太快)
- 只引入Redisson,自己创建客户端
- 引入项目依赖Redisson类库
<!--https://github.com/redisson/redisson#quick-start--><dependency><groupId>org.redisson</groupId><artifactId>redisson</artifactId><version>3.21.3</version></dependency> - 新建redisson客户端
/*** redisson配置*/ @Configuration @ConfigurationProperties(prefix = "spring.redis") @Data public class RedissonConfig {private String host;private String port;@Beanpublic RedissonClient redissonClient(){// 1. 创建配置对象Config config = new Config();String redisAddress = String.format("redis://%s:%s",host,port);config.useSingleServer().setAddress(redisAddress).setDatabase(3);// 2. 创建实例RedissonClient redisson = Redisson.create(config);return redisson;} } - 使用锁实现缓存预热
waitTime = 0 只抢一次/*** 缓存预热任务*/ @Slf4j public class PreCacheJob {@Resourceprivate RedisTemplate<String, Object> redisTemplate;@Resourceprivate UserService userService;@Resourcepublic UserMapper userMapper;//重点用户private List<Long> mainUserList = Arrays.asList(1L);//引入redisson客户端@Resourceprivate RedissonClient redissonClient;//每天执行,预热推荐用户@Scheduled(cron = "0 31 19 * * ? ")public void doCacheRecommendUser() {RLock lock = redissonClient.getLock("yupao:precachejob:docache:lock");try {//waitTime:其他线程等待的时间,因为我们缓存预热每天只做一次,所以只要有一个线程拿到锁就//leaseTime:锁过期时间if (lock.tryLock(0, 30000L, TimeUnit.MILLISECONDS)) {//是否拿到锁for (Long userId : mainUserList) {QueryWrapper<User> queryWrapper = new QueryWrapper<>();Page<User> userPage = userService.page(new Page<>(1, 20),queryWrapper);String redisKey = String.format("yupao:user:recommend:%s", userId);ValueOperations<String, Object> valueOperations =redisTemplate.opsForValue();//写缓存try {valueOperations.set(redisKey, userPage, 30000,TimeUnit.MILLISECONDS);} catch (Exception e) {log.error("redis set key error", e);}}}} catch (InterruptedException e) {log.error("doCacheRecommendUser error",e);} finally {//释放自己的锁if (lock.isHeldByCurrentThread()) {//是否是当前线程System.out.println("unlock: " + Thread.currentThread().getId());lock.unlock();}}} }
- 引入项目依赖Redisson类库
相关文章:
java分布式锁分布式锁
java分布式&锁&分布式锁 锁 锁的作用:有限资源的情况下,控制同一时间段,只有某些线程(用户/服务器)能访问到资源。 锁在java中的实现: synchronized关键字并发包的类 缺点:只对单个的…...
2. 流程控制|方法|数组|二维数组|递归
文章目录 流程控制代码块选择结构循环结构跳转控制关键字 方法方法的概述方法的重载Junit单元测试初识全限定类名 Debug 小技巧数组数组的基本概念数组的基本使用数组的声明数组的初始化 JVM内存模型什么是引用数据类型基本数据类型和引用数据类型的区别堆和栈中内容的区别 数组…...
22. 自动装配有哪些限制(需要注意)?
自动装配有哪些限制(需要注意)? 一定要声明set方法覆盖: 你仍可以用 < constructor-arg >和 < property > 配置来定义依赖,这些配置将始终覆盖自动注入。基本数据类型:不能自动装配简单的属性,如基本数据…...
14 网关实战:网关聚合API文档
上节课介绍了网关层的认证鉴权,今天这节介绍一下网关层如何聚合API接口文文档。 为什么需要聚合API接口文档? 大型微服务系统模块众多,木谷博客系统就有9个,如果这些服务的接口地址没有一个统一,那么客户端将要保存每个服务的接口地址,这个肯定是不现实。 先来看一下A…...
css 固定按钮到页面顶部或者底部的实现方式
实现方式 要将按钮固定到顶部或底部,可以使用CSS的定位属性来实现。下面是一种常用的方法: 创建一个包含按钮的HTML元素,例如一个<div>元素。确保给它添加一个唯一的id,以便在CSS中进行定位。 <div id"myButton&qu…...
【Java Spring】SpringBoot常用插件
文章目录 1、Lombok1.1 IDEA社区版安装Lombok1.2 IDEA专业版安装Lombok1.3 Lombok的基本使用 2、EditStarters2.1 IDEA安装EditStarters2.2 EditStarters基本使用方法 1、Lombok 是简化Java开发的一个必要工具,lombok的原理是编译过程中将lombok的注解给去掉并翻译…...
GPT还远远不是真正的智能
GPT是一个基于深度学习的自然语言处理模型,它可以生成逼真的文本。虽然GPT在生成文本方面取得了显著的进展,但它并不具备真正的智能。GPT是通过训练模型来学习语言模式,它不具备理解、推理、判断和主动学习的能力。它只是根据已有的语料库生成…...
计算机网络:网络层
0 本节主要内容 问题描述 解决思路 1 问题描述 两大问题(重点,也是难点): 地址管理;路由选择。 1.1 子问题1:地址管理 网络上的这些主机和节点都需要使用一种规则来区分,就相当于是一种身…...
消息队列进阶-1.消息队列的应用场景与选型
👏作者简介:大家好,我是爱吃芝士的土豆倪,24届校招生Java选手,很高兴认识大家📕系列专栏:Spring源码、JUC源码、Kafka原理🔥如果感觉博主的文章还不错的话,请ὄ…...
浅谈堆和栈内存以及编程语言
浅谈堆和栈内存以及编程语言 栈和堆C 和 C# 的区别:C#总结 编程语言C汇编语言(Assembly Language):机器语言(Machine Language): 拓展C#依赖注入(Dependency Injection)模…...
SpringBootWeb案例_01
Web后端开发_04 SpringBootWeb案例_01 原型展示 成品展示 准备工作 需求&环境搭建 需求说明: 完成tlias智能学习辅助系统的部门管理,员工管理 环境搭建 准备数据库表(dept、emp)创建springboot工程,引入对应…...
C语言数据结构-----栈和队列练习题(分析+代码)
前言 前面的博客写了如何实现栈和队列,下来我们来看一下队列和栈的相关习题。 链接: 栈和队列的实现 文章目录 前言1.用栈实现括号匹配2.用队列实现栈3.用栈实现队列4.设计循环队列 1.用栈实现括号匹配 此题最重要的就是数量匹配和顺序匹配。 用栈可以完美的做到…...
uniapp基础-教程之HBuilderX配置篇-01
uniapp教程之HBuilderX配置篇-01 为什么要做这个教程的梳理,主要用于自己学习和总结,利于增加自己的积累和记忆。首先下载HBuilderX,并保证你的软件在C盘进行运行,最好使用英文或者拼音,这个操作是为了保证软件的稳定…...
【备忘录】快速回忆ElasticSearch的CRUD
导引——第一条ElasticSearch语句 测试分词器 POST /_analyze {"text":"黑马程序员学习java太棒了","analyzer": "ik_smart" }概念 语法规则 HTTP_METHOD /index/_action/IDHTTP_METHOD 是 HTTP 请求的方法,常见的包括…...
影响PPC广告成本预算的因素,如何计算亚马逊PPC广告预算——站斧浏览器
亚马逊PPC,又称按点击付费(Pay Per Click),是一种只有用户点击你的广告时才会向你收费的模式。那么影响PPC广告成本预算的因素,如何计算亚马逊PPC广告预算? 影响PPC广告成本预算的因素 1、产品类别:不同类别的产品竞争程度不同&…...
Qt 信号和槽
目录 概念 代码 mainwindow.h me.h xiaohuang.h main.cc mainwindow.cc me.cc xianghuang.cc mainwindow.ui 自定义信号的要求和注意事项: 自定义槽的要求和注意事项: 概念 信号槽是 Qt 框架引以为豪的机制之一。所谓信号槽,实际就是观察者模式(发布-订…...
Linux基本命令二
Linux基本命令二 1、head 命令 head **作用:**用于查看文件的开头部分的内容,有一个常用的参数 -n 用于显示行数,默认为 10,即显示 10 行的内容 **语法:**head [参数] [文件] 命令参数: 参数…...
isbn api开放接口
接口地址:http://openapi.daohe168.com.cn/api/library/isbn/query?isbn9787115618085&appKeyd7c6c07a0a04ba4e65921e2f90726384 响应结果: { "success": true, "code": "200", "message": …...
助力企业实现更简单的数据库管理,ATOMDB 与 TDengine 完成兼容性互认
为加速数字化转型进程,当下越来越多的企业开始进行新一轮数据架构改造升级。在此过程中,全平台数据库管理客户端提供了一个集中管理和操作数据库的工具,提高了数据库管理的效率和便利性,减少了人工操作的复杂性和错误率࿰…...
如何通过低代码工具,提升运输行业的运营效率和服务质量
《中国数字货运发展报告》显示,2022年我国公路货运市场规模在5万亿元左右。其中,数字货运整体市场规模约为7000亿元,市场渗透率约为15%。而以小微企业为主的货运行业,却以小、散、乱的行业特征,承载着5万亿元左右的市场…...
利用域代码实现Word中Mathtype公式的智能编号与精准交叉引用
1. 为什么需要智能编号与交叉引用 写论文或者技术文档时,公式编号绝对是让人头疼的问题。我当年写硕士论文时,光是调整公式编号就浪费了整整两天时间。最让人崩溃的是,当你插入新公式后,后面的所有编号都要手动修改,更…...
Ubuntu 18.04下Intel Realsense D435i深度相机从驱动安装到3D图像采集全流程指南
Ubuntu 18.04环境下Intel Realsense D435i深度相机实战指南 在机器人研发和计算机视觉领域,深度相机正成为环境感知的核心传感器。Intel Realsense D435i凭借其双目红外摄像头、RGB传感器和内置IMU模块的硬件配置,为SLAM、三维重建等应用提供了高性价比…...
别只盯着算法!手把手教你为STM32MP157人脸识别项目搭建Qt图形界面
从算法到产品:STM32MP157人脸识别项目的Qt界面实战指南 当你在STM32MP157上成功跑通OpenCV人脸识别算法后,是否发现这离真正的产品化还有段距离?一个没有友好界面的嵌入式AI项目,就像没有方向盘的跑车——性能再强也难以驾驭。本文…...
终极指南:3步学会用sndcpy将手机音频无线传输到电脑
终极指南:3步学会用sndcpy将手机音频无线传输到电脑 【免费下载链接】sndcpy Android audio forwarding PoC (scrcpy, but for audio) 项目地址: https://gitcode.com/gh_mirrors/sn/sndcpy 你是否曾想过将手机上的游戏音效、音乐或会议录音实时传输到电脑上…...
Clawdbot惊艳效果:Qwen3-32B在创意写作(小说分章/剧本生成)中的连贯性展示
Clawdbot惊艳效果:Qwen3-32B在创意写作(小说分章/剧本生成)中的连贯性展示 1. 为什么创意写作特别需要“连贯性”这个能力 写小说和剧本,最难的从来不是开头那几句话,而是让故事像一条活水一样自然流淌下去。你有没有…...
如何实现SQL复杂计算触发器原子性_利用触发器事务控制
是,触发器天然包含在主SQL事务中;其数据修改随主语句回滚,无需手动开启事务,但不可修改被主语句操作的同一张表。触发器里写复杂SQL计算,事务会自动包含吗会。只要触发器在支持事务的存储引擎(比如 InnoDB&…...
Windows Cleaner终极指南:三步解决C盘爆红问题
Windows Cleaner终极指南:三步解决C盘爆红问题 【免费下载链接】WindowsCleaner Windows Cleaner——专治C盘爆红及各种不服! 项目地址: https://gitcode.com/gh_mirrors/wi/WindowsCleaner Windows Cleaner是一款专为Windows系统设计的开源清理优…...
高并发异步爬虫落地:单机日采百万数据,性能提升10倍的优化方案
背景:之前做电商价格监测项目时,最开始写的同步爬虫一天只能爬10万条数据,服务器都跑满了还是不够用。后来一步步优化,改成异步协程连接池复用的架构,单机一天就能爬120万条数据,CPU占用还不到30%。一、优化…...
10分钟上手:忍者像素绘卷在PyCharm中的开发与调试技巧
10分钟上手:忍者像素绘卷在PyCharm中的开发与调试技巧 1. 前言:为什么选择PyCharm开发忍者像素绘卷 忍者像素绘卷是一款基于深度学习的像素风格图像生成工具,能够根据文本描述快速生成复古游戏风格的像素画。对于Python开发者来说ÿ…...
Qwen-Image-Edit快速上手:基于深度显存优化,普通显卡也能流畅运行
Qwen-Image-Edit快速上手:基于深度显存优化,普通显卡也能流畅运行 1. 项目概述 Qwen-Image-Edit是由阿里通义千问团队开源的一款创新性图像编辑工具,通过深度显存优化技术,让普通显卡也能流畅运行高质量的AI图像编辑。这个工具最…...
