当前位置: 首页 > article >正文

【redis笔记】分布式锁

什么需要分布式锁

分布式场景下,原单机的多进程多线程并发控制策略会失效,典型的像海量key分布在redis集群中,那么对这些key的并发修改操作就不像单机那样容易保证有序(单机的锁只对单机有效),这时就需要使用分布式锁来实现并发控制。
通常可以有以下几种分布式锁实现方式:

  • 基于数据库实现
  • 基于redis实现
  • 基于Zookeeper实现

我们可以使用redis来实现分布式的锁来控制分布式应用的并发策略。利用的是setnx在已经设置值后,会返回0的特性。

怎么避免分布式锁一直被占用

通常我们需要避免某个任务一直占用锁导致其他任务无法顺利执行的场景,我们可以通过设置锁的过期时间来让锁自动失效。
为了上锁后如果出现redis服务异常,导致过期时间设置失败,一般上锁时要同步进行过期时间设置,如下上锁并设置lock过期时间10秒

set lock 1 nx ex 10

怎么避免锁被误删除

考虑以下场景,A加了一把锁,过期时间3秒,在手动释放锁之前过期了,B这时加锁进行了自己的操作,这时A执行到了解锁,就会导致A把B加的锁删除了
一种有效的解决方案是每个具体的服务生成一个uuid,当我们加锁时,我们把值设置成自己的uuid,释放锁的时候去获取此时锁的uuid值,如果一样就释放,不一样就不释放。
但由于比较和删除的操作不是原子的,如果我们比较是否相等之后,还没删除,就过期了,如果刚好被另外一个服务抢占了,那么还是会误删除。为了解决这个问题,我们也可以使用LUA脚本来保证执行的原子性


http://www.kler.cn/a/161651.html

相关文章:

  • 2个word内容合并
  • SHA-256哈希函数
  • 用MVVM设计模式提升WPF开发体验:分层架构与绑定实例解析
  • 【机器学习】如何配置anaconda环境(无脑版)
  • SpringCloud学习笔记
  • HBase理论_背景特点及数据单元及与Hive对比
  • 在 CentOS 或 Red Hat 系统上安装 Citus 组件
  • Gateway
  • Hive增强的聚合、多维数据集、分组和汇总
  • 动手学深度学习——Anaconda、pytorch、paddle安装(cpu版本)
  • Python-封装配置文件
  • 学习-ES
  • 三层交换机配置DHCP服务
  • 在vue中深度选择器的使用
  • 什么是css初始化
  • 代客泊车手势召车功能设计规范
  • 【计算机网络学习之路】HTTP响应报文Cookie原理
  • 玩转Sass:掌握数据类型!
  • postgreSql逻辑复制常用语句汇总和说明
  • SQL Server权限管理与数据恢复
  • Spring Boot HTTP 400 错误的日志信息在哪里查看 ?
  • 互联网洗鞋上门预约小程序预约下单系统源码公众号源码H5
  • 创建vue项目:node.js下载安装、配置环境变量,下载安装cnpm,配置npm的目录、镜像,安装vue、搭建vue项目开发环境(保姆级教程一)
  • office办公技能|ppt插件使用
  • 要求CHATGPT高质量回答的艺术:提示工程技术的完整指南—第 22 章:情感分析提示
  • QT作业1