首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >似乎redisson分布式锁不起作用。

似乎redisson分布式锁不起作用。
EN

Stack Overflow用户
提问于 2020-06-09 08:49:12
回答 1查看 405关注 0票数 0

我正在测试redisson的分布式锁是否正确工作,使用kotlin和coroutine。

代码语言:javascript
运行
复制
    runBlocking {
        repeat(1000) {
            launch {
                val lock = nonReactiveClient.getLock("lock")
                if(lock.tryLock(5, 5, TimeUnit.SECONDS)) {
                    try {
                        val value = test.get()
                        delay(10L)
                        test.set(value + 3)
                    } finally {
                        lock.unlock()
                    }
                }
            }
        }
    }

我认为结果值应该是3000,因为分布式锁保证'get‘和'set’操作将一起执行。

但当我试图获得价值时,我得到了以下结果:

代码语言:javascript
运行
复制
127.0.0.1:6379> get test
"3"

我做错什么了?

EN

回答 1

Stack Overflow用户

发布于 2022-04-17 06:59:21

在Coroutines中,在delay之后,可以更改线程上下文。

lock.tryLock -线程id - 77

lock.unlock -线程id - 88 (无限等待)

您可以在不同线程id下使用forceUnlock()

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/62278579

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档