【redis】redis分布式锁(三)自动续期

这篇具有很好参考价值的文章主要介绍了【redis】redis分布式锁(三)自动续期。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

系列文章目录

【redis】redis分布式锁(一)手写分布式锁1.0~6.0
【redis】redis分布式锁(二)可重入锁+设计模式



前言

【redis】redis分布式锁(三)自动续期


一、CAP

【redis】redis分布式锁(三)自动续期

redis集群 AP

在主节点set的值,但是在复制给从机过程中宕机了,这时候从机上位是不能获取这个值的
【redis】redis分布式锁(三)自动续期

ZooKeeper集群 CP 数据一致性

CP:
【redis】redis分布式锁(三)自动续期
故障:牺牲了高可用,即在一台master宕机后,选举新master时,zk服务不可用
【redis】redis分布式锁(三)自动续期

Eureak集群 AP

AP:
【redis】redis分布式锁(三)自动续期

nacos集群 AP

【redis】redis分布式锁(三)自动续期

二、lua脚本

脚本:if redis.call('HEXISTS',KEYS[1],ARGV[1]) == 1 then return redis.call('expire',KEYS[1],ARGV[2]) else return 0 end

【redis】redis分布式锁(三)自动续期


三、融合进业务类

在锁的代码
【redis】redis分布式锁(三)自动续期

【redis】redis分布式锁(三)自动续期
主线程代码
【redis】redis分布式锁(三)自动续期
执行:
【redis】redis分布式锁(三)自动续期


四、redis分布式锁的总结

【redis】redis分布式锁(三)自动续期

V1.0 和 V2.0 单机锁

【redis】redis分布式锁(三)自动续期

V3.0 和 V4.0 finally删除锁、自旋、过期时间、lua脚本保证原子化执行

【redis】redis分布式锁(三)自动续期

V5.0 和 V6.0 5.0删除锁时需要同时判断锁是否为自己的,6.0unlock用到lua脚本原子化执行。至此,小厂可以使用V6.0版本。

【redis】redis分布式锁(三)自动续期

V7.0 可重入锁 使用hset来替代原来的setnx、lua脚本、以及实现Lock接口的AQS规范、工厂模式的引入

【redis】redis分布式锁(三)自动续期
【redis】redis分布式锁(三)自动续期文章来源地址https://www.toymoban.com/news/detail-431246.html

V8.0 自动续期 保证锁在业务类执行期间不会过期,自动续期


到了这里,关于【redis】redis分布式锁(三)自动续期的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 中间件系列 - Redis入门到实战(高级篇-分布式缓存)

    学习视频: 黑马程序员Redis入门到实战教程,深度透析redis底层原理+redis分布式锁+企业解决方案+黑马点评实战项目 中间件系列 - Redis入门到实战 本内容仅用于个人学习笔记,如有侵扰,联系删除 学习目标 Redis持久化 Redis主从 Redis哨兵 Redis分片集群 - 基于Redis集群解决单机R

    2024年02月03日
    浏览(53)
  • Python爬虫之Scrapy框架系列(23)——分布式爬虫scrapy_redis浅实战【XXTop250部分爬取】

    先用单独一个项目来使用scrapy_redis,讲解一些重要点!

    2024年02月16日
    浏览(56)
  • 一篇文章介绍分布式事务

    事务 事务指的就是一个操作单元,在这个操作单元中的所有操作最终要保持一致的行为,要么所有操作都成功,要么所有的操作都被撤销。简单地说,事务提供一种“要么什么都不做,要么做全套”机制。 本地事务 本地事务其实可以认为是数据库提供的事务机制。说到数据

    2023年04月23日
    浏览(39)
  • Redis与分布式-分布式锁

    接上文 Redis与分布式-集群搭建 为了解决上述问题,可以利用分布式锁来实现。 重新复制一份redis,配置文件都是刚下载时候的不用更改,然后启动redis服务和redis客户。 redis存在这样的命令:和set命令差不多,但是它有一个机制,当指定的key不存在的时候,才能进行插入,实

    2024年02月07日
    浏览(50)
  • 文章学习:TPRE:分布式门限代理重加密

    学习文章:TPRE:分布式门限代理重加密 成方金科新技术实验室与隐语团队合作,构建了“ 基于国密的分布式门限代理重加密算法TPRE ”,为用户提供了一种安全、高效、自主可控的数据共享和授权管理方案。在 数据隐私保护 和 数据安全共享 方面具有广泛的应用前景。 ⚠️

    2024年02月01日
    浏览(56)
  • 文章学习:TPRE-分布式门限代理重加密

    学习文章:TPRE:分布式门限代理重加密 成方金科新技术实验室与隐语团队合作,构建了“ 基于国密的分布式门限代理重加密算法TPRE ”,为用户提供了一种安全、高效、自主可控的数据共享和授权管理方案。在 数据隐私保护 和 数据安全共享 方面具有广泛的应用前景。 ⚠️

    2024年02月01日
    浏览(53)
  • 【分布式和微服务1】一篇文章详细了解分布式和微服务的基本概念

    🍀 通俗一点说,高可用的意思是:在 高 并发的情况下,系统仍然是 可用 的 🍀 高可用的目的:保障业务的连续性( 实现在用户眼里,业务永远是正常对外提供服务的 ) 🍀 🍬 【上图】一个 SpringBoot 项目( apple.jar )被部署到服务器上运行,可向其发送 网络请求 对 数据

    2024年02月02日
    浏览(69)
  • Redis分布式锁和分布式事务

    Redis分布式锁和分布式事务 一、Redis分布式锁 1.1 watch和事务实现分布式锁 原理是通过watch来观察一个变量,一个线程在操作的时候,其他线程会操作失败,相当于乐观锁。 1.2 setnx实现分布式锁 原理是通过setnx设置一个变量,设置成功的线程抢到锁,执行相关的业务,执行完毕

    2024年02月09日
    浏览(45)
  • Redis缓存设计与性能优化【缓存和数据库不一致问题,解决方案:1.加过期时间这样可以一段时间后自动刷新 2.分布式的读写锁】

    在大并发下,同时操作数据库与缓存会存在数据不一致性问题 1、双写不一致情况 2、读写并发不一致 解决方案: 1、对于并发几率很小的数据(如个人维度的订单数据、用户数据等),这种几乎不用考虑这个问题,很少会发生缓存不一致, 可以给缓存数据加上过期时间,每隔一

    2024年04月13日
    浏览(54)
  • 【redis】redis分布式锁

    一、为什么需要分布式锁 1.在java单机服务中,jvm内部有一个全局的锁监视器,只有一个线程能获取到锁,可以实现线程之间的互斥 2.当有多个java服务时,会有多个jvm,也会有多个锁监视器,这样没办法使得多个jvm之间的线程互斥,所以无法使用jvm内部的锁监视器,也就是s

    2023年04月25日
    浏览(46)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包