码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • redis的锁


    redis分布式锁

    分布式锁:在分布式系统下保证多线程互斥并可见;即让不同服务器的线程共同使用一把锁

    分布式锁的缺陷

    锁失效:持有锁是client 1由于网络原因陷入阻塞,业务为执行完锁便过期

    时钟漂移:Client 1 获取锁后,定义了过期时间,由于redis本身时钟若比Client不同可能产生锁相对于redis提前失效,但client还持有锁,此时Client 2再次分配到锁,就会出现多线程同有一把琐的情况

    redis实现分布式锁:

    利用redis的SETNX命令,该命令为原子性操作,只有Key不存在,Set才能获取成功;具体流程为:

    1. 获取当前时间

    2. 依次N个节点获取锁,设置锁响应超时时间

    3. 在锁的过期时间内,成功获取锁的节点数大于N/2 + 1,说明获取锁成功;

    4. 若获取锁失败,则向所有结点释放锁

    redis的加锁机制:SETNX命令

    SETNX:SET if Not eXists:如果不存在则set;

    使用ex设置超时时间

    1. #在添加时存在则添加,不存在则不添加。同时设置过期时间,单位秒
    2. SET key value NX EX time

    Lua脚本为什么能够保证原子性:

    Lua脚本能够保证原子性的主要原因还是Redis采用了单线程执行模型。也就是说,当Redis执行Lua脚本时,Redis会把Lua脚本作为一个整体并把它当作一个任务加入到一个队列中,然后单线程按照队列的顺序依次执行这些任务,在执行过程中Lua脚本是不会被其他命令或请求打断,因此可以保证每个任务的执行都是原子性的。

  • 相关阅读:
    SpringBoot保姆级教程(五)SpringBoot注册web组件
    博客自动化测试
    华为交换机配置ACL
    Apache Doris (五十一): Doris数据缓存
    Maven系列:第1篇:什么是maven?为什么需要它?
    电子邮件地址注册过程详解
    python独立脚本应用Django项目的环境
    LibOpenCM3(五) 基础功能: 系统时钟, GPIO, 定时器
    十五届蓝桥杯软件和信息技术大赛
    java计算机毕业设计医院远程诊断系统源代码+系统+数据库+lw文档
  • 原文地址:https://blog.csdn.net/ggggggzzzzz/article/details/132866259
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号