redis分布式锁的应用场景有哪些_分布式锁使用场景举例

redis分布式锁的应用场景有哪些_分布式锁使用场景举例为什么需要分布式锁分布式锁是实现用户进程同步的一种方式,需要注意的是,Redis是分布式锁实现的一种技术,而不是作用对象多用户进程请求服务的场景很多,为什么分布式锁并不普遍应用?首先需要定义一下分布式锁的原理和使用场景使用场景原子锁—线程同步,一个程序下的多线程之间对于共享变量进行同步,如计数器分布式锁—进程同步,集群下的多服务进程之间对于共享资源进行同步,如数据库可以明确的是数据库已经实现这种“锁”的机制了,因为它的事务锁机制,虽然多个用户I/O之间会出现数据短暂的不.

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

为什么需要分布式锁

分布式锁是实现用户进程同步的一种方式,需要注意的是,Redis是分布式锁实现的一种技术,而不是作用对象

多用户进程请求服务的场景很多,为什么分布式锁并不普遍应用?首先需要定义一下分布式锁的原理和使用场景 

使用场景

原子锁—线程同步,一个程序下的多线程之间对于共享变量进行同步,如计数器

分布式锁—进程同步,集群下的多服务进程之间对于共享资源进行同步,如数据库

redis分布式锁的应用场景有哪些_分布式锁使用场景举例

可以明确的是数据库已经实现这种“锁”的机制了,因为它的事务锁机制,虽然多个用户I/O之间会出现数据短暂的不一致,长期还是可以保证数据一致性的

不需要进程同步的场景:因为多个用户进程的请求是相对独立的,不受彼此影响或影响不大的(两个都不是持久化请求,即写+写),例如,A开放权限B访问页面属于写+读,同时搜索信息属于读+读

需要进程同步的场景:多个用户进程的请求是互相影响的(两个都是持久化请求,写+写),例如,秒杀系统防止超卖,占位抢票

Redis加锁

需要满足以下特性,因此用到两个命令

独占性:如果锁已经被占用,线程需要阻塞等待—setnx

时效性:锁超过一定时间自动释放—setex

对于共享的Jedis连接,操作需要原子性:

jedis.set(KEY,VALUE,”NX”,”PX”,EXPIRE_TIME);

KEY—锁的密钥

VALUE—用户请求ID/线程ID

“NX”—setnx

“PX”—setex

EXPIRE_TIME—失效时间

代码示例

    private static final String LOCK_SUCCESS = "OK";

    public static boolean lock(Jedis jedis,String KEY,String VALUE,int EXPIRE_TIME) {
        String success = jedis.set(KEY, VALUE, "NX", "PX", EXPIRE_TIME);
        return LOCK_SUCCESS.equals(success);
    }

Redis解锁

需要解决一个问题,因此用到两个命令

避免误删:进程A超时,锁被释放,进程B获得锁,此时进程A删除了KEY,解决方法“解铃还须系铃人”,需要校验传入的VALUE,即用户请求ID,伪代码if get(KEY)=VALUE then del(KEY)

同样地,需要通过一个Jedis的命令实现原子性

jedis.eval(SCRIPT, KEY, VALUE);

SCRIPT—LUA脚本来完成KEY-VALUE校验和删除KEY两个步骤,保证原子性

KEY—锁的密钥

VALUE—用户请求ID/线程ID

代码示例

private static final Long RELEASE_SUCCESS = 1L;

public static boolean release(Jedis jedis,String KEY,String VALUE) {
    String script="if redis.call('get',KEYS[1]) == ARGV[1] then return redis.call('del', KEYS[1]) else return 0 end";
    Object success = jedis.eval(script, Collections.singletonList(KEY),Collections.singletonList(VALUE));
    return RELEASE_SUCCESS.equals(success);
}

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

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

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

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

(0)


相关推荐

  • Linux虚拟存储管理分析[通俗易懂]

    Linux虚拟存储管理分析[通俗易懂]Linux虚拟存储管理分析摘 要:本文通过解剖Linux操作系统的虚拟存储管理机制,说明了Linux虚拟存储的特点、虚拟存储器的实现方法,并基于LinuxKernelSource1.0,详细分析有关虚拟存诸管理的主要数据结构之间的关系。关键字:Linux操作系统内存管理虚拟存储        Linux操作系统是一种多用户多任务、支持多种平台的开源的类Unix操作系统,

  • 通俗理解kaggle比赛大杀器xgboost

    通俗理解kaggle比赛大杀器xgboost通俗理解kaggle比赛大杀器xgboost说明:若出现部分图片无法正常显示而影响阅读,请以此处的文章为准:xgboost题库版。时间:二零一九年三月二十五日。0前言xgboost一直在竞赛江湖里被传为神器,比如时不时某个kaggle/天池比赛中,某人用xgboost于千军万马中斩获冠军。而我们的机器学习课…

  • pytest的assert_java单元测试断言

    pytest的assert_java单元测试断言前言断言是写自动化测试基本最重要的一步,一个用例没有断言,就失去了自动化测试的意义了。什么是断言呢?简单来讲就是实际结果和期望结果去对比,符合预期那就测试pass,不符合预期那就测试failed

  • IOCP配合AcceptEX「建议收藏」

    IOCP配合AcceptEX「建议收藏」IOCP配合AcceptEx的例子(1)(2006-7-214:33:00)【收藏】【评论】【打印】【关闭】标签:C++ VC 网络 服务器 在论坛找到的,搬进来备查,呵呵感谢作者的辛苦劳动:)作者:chang290     发表时间:2005-12-1716:38:00     这是在学《Windows网络

  • 面试官,不要再问我三次握手和四次挥手「建议收藏」

    面试官,不要再问我三次握手和四次挥手「建议收藏」三次握手和四次挥手是各个公司常见的考点,也具有一定的水平区分度,也被一些面试官作为热身题。很多小伙伴说这个问题刚开始回答的挺好,但是后面越回答越冒冷汗,最后就歇菜了。见过比较典型的面试场景是这样的:面试官:请介绍下三次握手求职者:第一次握手就是客户端给服务器端发送一个报文,第二次就是服务器收到报文之后,会应答一个报文给客户端,第三次握手就是客户端收到报文后再给服务器发送一个报文,三次握手就…

  • 图片加载失败替换图片解决方案

    图片加载失败替换图片解决方案图片加载失败在不同浏览器表现有差异,比如google可能会一片空白、img的宽高是0*0,ie会在图片位置会出现一个碎片图标,火狐会显示一个边框像这样:一个页面如果很多这种好难看,一般会用默认图片替换显示,解决方法:1、css方案:不好使。在img的伪类加替换图片,但火狐的img没有伪类,google有,有时候就算给img标签加了width、height也没有,图片加载失败img的宽高…

发表回复

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

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