考虑在午夜发生两个并发事务。两者都可以执行get(dt_key),但是将首先执行MULTI /
EXEC块。它将重置计数器,设置新日期,增加计数器。第二个也将输入其MULTI /
EXEC块中,但由于’dt’的值已更改,执行将失败,并且将再次调用incr_daily_number。这次get(dt_key)将返回新的日期,因此当执行MULTI
/ EXEC块时,计数器将递增而不进行任何复位。这两个事务将返回具有不同计数器值的新日期。
因此,我相信这里没有比赛条件,并且(日期,数字)对将是唯一的。
您还可以使用服务器端Lua脚本(其执行始终是原子的)来实现此目的。通常更方便。
请注意,实际上,没有Redis锁之类的东西。API中可用的锁定机制由Python客户端提供,而不是由Redis服务器提供。如果看一下它的实现,您将意识到它也是基于SETNX
+ WATCH / MULTI / EXEC块或Lua脚本编写的。



