原子操作来实现并发
为了实现并发访问的正确性,redis提供了两种方法,加锁和原子操作,但是由于加锁会降低redis的性能,所以推荐使用原子操作的方式。
并发访问操作主要是对数据进行修改,分为读取,修改,写回这三步,如果不对其控制,会导致错误。
redis提供了两种方法避免这个问题
单命令操作
由于redis本身是单命令操作的,命令之间是互斥的。所以我们可以把读取,修改,写回,这三个步骤变成一个命令,单命令,再加上redis的互斥,就能保障并发控制了。
比如INCR/DECR
Lua脚本
但是有些命令,没那么简单,需要根据实际需求去调整,这个时候我们可以采用Lua脚本的方式。Redis 会把整个 Lua 脚本作为一个整体执行,在执行的过程中不会被其他命令打断,从而保证了 Lua 脚本中操作的原子性。