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

响应式学校网站模板百度400电话

响应式学校网站模板,百度400电话,云开发小程序源码,免费顶级域名网站注册目录 一、基本原理 二、源码解析: (2)获取锁 (1)释放锁: 之前给大家介绍过redisson的分布式锁,用redisson来实现比自己手搓简单的分布式锁有很多好处,因为这些可重入、可重试的逻…

目录

一、基本原理

二、源码解析:

(2)获取锁

(1)释放锁:


       

        之前给大家介绍过redisson的分布式锁,用redisson来实现比自己手搓简单的分布式锁有很多好处,因为这些可重入、可重试的逻辑较为复杂,他们的lua脚本不可能让我们在开发时自己实现,这样太耗时间了。所以redisson就帮我们实现了可重入和可重试。但我们也要知道他的原理,这期我们先讲可重入。


上一篇:

【Redisson】快速实现分布式锁-CSDN博客


一、基本原理

基本原理:

(1)获取锁的时候,还是使用setnx命令,如果该锁还没有被获取过,直接set,也就是获取锁成功

(2)当该线程第二次获取锁时,因为锁已经被获取了,也就是setnx返回false。这时候,先不直接返回获取锁失败的逻辑,而是先判断该锁的value值是不是自己,如果是,那么就获取锁成功。

(3)有一个计数器,每次获取锁成功计数器就+1,每次释放锁的时候计数器就-1。当计数器为0的时候表明该线程所有重入的锁都被释放完毕了,就可以删除这个key。那么其他线程就可以获取锁了

(4)因为key的value值既要记录线程标识,也要记录重入次数。所以String类型的结构就不满足了。需要使用到hash结构

(5)注意:每次释放锁时,如果value值不是0,说明该锁还是被该线程占用的。也就是释放重入锁的时候,要重置锁的有效期

图解:



二、源码解析:

(2)获取锁

<T> RFuture<T> tryLockInnerAsync(long waitTime, long leaseTime, TimeUnit unit, long threadId, RedisStrictCommand<T> command) {return this.commandExecutor.syncedEvalNoRetry(this.getRawName(), LongCodec.INSTANCE, command, "local mode = redis.call('hget', KEYS[1], 'mode');" +"   if (mode == false) then " +"       redis.call('hset', KEYS[1], 'mode', 'read');" +"       redis.call('hset', KEYS[1], ARGV[2], 1);" +"       redis.call('set', KEYS[2] .. ':1', 1);" +"        redis.call('pexpire', KEYS[2] .. ':1', ARGV[1]);" +"       redis.call('pexpire', KEYS[1], ARGV[1]);" +"       return nil;" +"   end;" +"   if (mode == 'read') or (mode == 'write' and redis.call('hexists', KEYS[1], ARGV[3]) == 1) then" +"        local ind = redis.call('hincrby', KEYS[1], ARGV[2], 1);" +"        local key = KEYS[2] .. ':' .. ind;redis.call('set', key, 1);" +"        redis.call('pexpire', key, ARGV[1]);" +"        local remainTime = redis.call('pttl', KEYS[1]);" +"        redis.call('pexpire', KEYS[1], math.max(remainTime, ARGV[1]));" +"        return nil;" +"   end;" + "return redis.call('pttl', KEYS[1]);",Arrays.asList(this.getRawName(), this.getReadWriteTimeoutNamePrefix(threadId)), new Object[]{unit.toMillis(leaseTime), this.getLockName(threadId), this.getWriteLockName(threadId)});}

解析:

(1)释放锁:

解析: 

http://www.dtcms.com/wzjs/346234.html

相关文章:

  • 站长如何做导航网站百度提交入口地址在哪
  • 我想在家办个小型加工厂绍兴网站快速排名优化
  • 恒美广告公司seo优化运营
  • 用xml可不可以做网站百度开户流程
  • 阆中市住房和城乡建设局网站内部优化
  • 网站流量变现网络营销工资一般多少
  • 如何做品牌网站设计营销组合策略
  • 网站模板插件怎么可以让百度快速收录视频
  • 建站平台转型优化是什么意思
  • 网络服务和 网络管制问题重庆seo网页优化
  • 网站的导航用css怎么做网站宣传方法
  • wordpress 文章自定义手机卡顿优化软件
  • 哈尔滨专业网站建设定制宁德市中医院
  • 用vb做网站网站搭建流程
  • 个人网站备案有什么限制seo实战密码第四版pdf
  • 搭网站可以用自己电脑做服务器吗互联网推广怎么找渠道
  • 有网站怎样做推广电脑优化软件哪个好用
  • 网站seo方案策划书指数基金定投技巧
  • steam课程做网站百度排名竞价
  • 深圳旅游必去十大景点青岛seo霸屏
  • 传媒网站设计免费网站 推广网站
  • 制作网站的公司百度免费广告发布平台
  • DW做旅游网站模板线上推广渠道有哪些
  • 做淘宝客网站需要注意什么今天有什么新闻
  • 通用集团网站模板百度收录申请入口
  • 报纸做垂直门户网站恢复正常百度
  • 我做的网站服务器别人没法左键点击下载呢输入关键词就能写文章的软件
  • 保定清苑城市建设网站企业网站有什么
  • 中国法院政务网站群建设培训会山东关键词优化联系电话
  • 站长网站模板网站推广策划思路的内容