
业务操作:取某个 key 的值,对改值进行计算,再将新值覆盖掉旧值。
可以用 watch,multi,exec 命令保证写操作的原子性,但是如何阻塞其他线程在该业务操作期中读取 key 的值。
1 kefirzhang 2021-03-12 16:43:01 +08:00 不行,redis 没有独占锁。你可以从业务逻辑上实现,删掉这个 key,然后在程序后再添加 |
2 myCupOfTea 2021-03-12 17:08:50 +08:00 话说你能保证原子性 为啥害怕被人读了 |
3 myCupOfTea 2021-03-12 17:09:42 +08:00 要不让整个 读->计算->写 操作变成原子操作吧 用 lua 写脚本就可以了 |
4 kefirzhang 2021-03-12 17:33:56 +08:00 这种其实最好还是在程序里面做一个排它锁,不是 redis 的事情就不要强加给 redis 了。 |
5 opengps 2021-03-12 17:36:28 +08:00 读应该是无所谓的,主要是删改的时候需要有锁来保证原子性 |
6 liian2019 2021-03-12 17:39:49 +08:00 非集群可以用 pipeline 。集群用 lua 。读+操作+写三个步骤原子性执行就好了 |
8 qianxiaoxiao 2021-03-12 17:44:41 +08:00 @kefirzhang 如果删掉后没有添加前 程序挂了怎么办 |
9 phony2r 2021-03-12 17:47:40 +08:00 彦祖, 我也不会 |
10 Varobjs 2021-03-12 17:58:17 +08:00 冠希啊,你换 MySQL 吧 |
11 mengdodo 2021-03-12 18:21:54 +08:00 我就搞不懂你为什么要覆盖 |
12 vegetableChick 2021-03-12 18:35:41 +08:00 马德华么?小明 |
13 linxiaojialin 2021-03-12 18:38:18 +08:00 等一等,有件事我们必须先搞清楚,你叫的是姓 [刘] 的还是姓 [马] 的 |
14 liujavamail 2021-03-12 18:41:38 +08:00 redis 分布式锁能用么? |
15 securityCoding 2021-03-12 20:20:57 +08:00 重命名呗 |
16 young1lin 2021-03-12 21:20:20 +08:00 你这要求不就是 Lua 脚本解决的么? |
17 johnsona 2021-03-13 04:30:53 +08:00 骂谁马德华呢 |
18 Takamine 2021-03-13 18:12:12 +08:00 via Android 我怎么觉得直接在业务上对这个 key 的操作包装的方法(块)是加锁的不就好了吗。 |
19 Kili9 2021-03-15 16:46:02 +08:00 redis+lua |