Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
weixin_57962205
redisson
提交
167d507c
R
redisson
项目概览
weixin_57962205
/
redisson
与 Fork 源项目一致
从无法访问的项目Fork
通知
10
Star
1
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
R
redisson
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
前往新版Gitcode,体验更适合开发者的 AI 搜索 >>
提交
167d507c
编写于
10月 28, 2020
作者:
W
wuqian30624
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Avoid redisson fair lock blocking if there are lots of registered threads in queue but not used.
Signed-off-by:
N
wuqian30624
<
wuqian0808@me.com
>
上级
24b49b01
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
16 addition
and
0 deletion
+16
-0
redisson/src/main/java/org/redisson/RedissonFairLock.java
redisson/src/main/java/org/redisson/RedissonFairLock.java
+16
-0
未找到文件。
redisson/src/main/java/org/redisson/RedissonFairLock.java
浏览文件 @
167d507c
...
...
@@ -201,6 +201,22 @@ public class RedissonFairLock extends RedissonLock implements RLock {
"return nil;"
+
"end;"
+
// check if the lock is not held, and other queues are not used
"while true do "
+
"local firstThreadId = redis.call('lindex', KEYS[2], 0);"
+
"if (firstThreadId == false) or (firstThreadId == ARGV[2]) then "
+
"break;"
+
"end;"
+
"local timeout = tonumber(redis.call('zscore', KEYS[3], firstThreadId));"
+
"if (timeout > tonumber(ARGV[4])) and (redis.call('exists', KEYS[1]) == 0) then "
+
"redis.call('lpop', KEYS[2]);"
+
"redis.call('zrem', KEYS[3], firstThreadId);"
+
"else"
+
"break;"
+
"end;"
+
"end;"
+
// the lock cannot be acquired
// check if the thread is already in the queue
"local timeout = redis.call('zscore', KEYS[3], ARGV[2]);"
+
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录