业务操作:取某个 key 的值,对改值进行计算,再将新值覆盖掉旧值。
可以用 watch,multi,exec 命令保证写操作的原子性,但是如何阻塞其他线程在该业务操作期中读取 key 的值。
1
kefirzhang 2021 年 3 月 12 日 不行,redis 没有独占锁。你可以从业务逻辑上实现,删掉这个 key,然后在程序后再添加
|
2
myCupOfTea 2021 年 3 月 12 日
话说你能保证原子性 为啥害怕被人读了
|
3
myCupOfTea 2021 年 3 月 12 日
要不让整个 读->计算->写 操作变成原子操作吧
用 lua 写脚本就可以了 |
4
kefirzhang 2021 年 3 月 12 日
这种其实最好还是在程序里面做一个排它锁,不是 redis 的事情就不要强加给 redis 了。
|
5
opengps 2021 年 3 月 12 日
读应该是无所谓的,主要是删改的时候需要有锁来保证原子性
|
6
liian2019 2021 年 3 月 12 日
非集群可以用 pipeline 。集群用 lua 。读+操作+写三个步骤原子性执行就好了
|
7
iamlbk 2021 年 3 月 12 日
或者让读到的线程假装没读到呢? 比如先把值改成 tmp_随机数:原始值
其他线程读到数据以后先判断是不是 tmp_ 开头的, 如果是的话 看看随机数确认是不是当前线程写进去的 如果不是当前线程写进去的 就认为没读到 按照 null 去执行后续逻辑 |
8
qianxiaoxiao 2021 年 3 月 12 日
@kefirzhang 如果删掉后没有添加前 程序挂了怎么办
|
9
phony2r 2021 年 3 月 12 日
彦祖, 我也不会
|
10
Varobjs 2021 年 3 月 12 日
冠希啊,你换 MySQL 吧
|
11
mengdodo 2021 年 3 月 12 日
我就搞不懂你为什么要覆盖
|
12
vegetableChick 2021 年 3 月 12 日
马德华么?小明
|
13
linxiaojialin 2021 年 3 月 12 日
等一等,有件事我们必须先搞清楚,你叫的是姓 [刘] 的还是姓 [马] 的
|
14
liujavamail 2021 年 3 月 12 日
redis 分布式锁能用么?
|
15
securityCoding 2021 年 3 月 12 日
重命名呗
|
16
young1lin 2021 年 3 月 12 日
你这要求不就是 Lua 脚本解决的么?
|
17
johnsona 2021 年 3 月 13 日
骂谁马德华呢
|
18
Takamine 2021 年 3 月 13 日 via Android
我怎么觉得直接在业务上对这个 key 的操作包装的方法(块)是加锁的不就好了吗。
|
19
Kili9 2021 年 3 月 15 日
redis+lua
|