redis设计与实现 书中说:
Redis的事务总是具有ACID中的原子性、一致性和隔离性,当服务器运行在AOF
持久化模式下,并且appendfsync选项的值为always时,事务也具有耐久性。
可看网上资料,又说redis事务不满足原子性和持久性:
在redis事务中如果有某一条命令执行失败,其后的命令仍然会被继续执行,并不会自动回滚;
在AOF的“总是 SYNC ”模式下,事务的每条命令在执行成功之后,都会立即调用fsync或fdatasync将事务数据写入到AOF文件。
但是,这种保存是由后台线程进行的,主线程不会阻塞直到保存成功,所以从命令执行成功到数据保存到硬盘之间,还是有一段非常小的间隔,所以这种模式下的事务也是不持久的。
求解答~~
Cela est principalement dû à des doutes sur l'atomicité de redis. Il a maintenant été vérifié que redis ne garantit pas l'atomicité. Lorsque l'exécution de la commande échoue dans la transaction, elle ne sera pas annulée.
Tout d'abord, redis est monothread, il n'y a donc pas de concept de transaction, à moins que vous n'utilisiez mutil pour encapsuler manuellement un ensemble de commandes et les exécuter dans leur ensemble, plus précisément, si une instruction dans l'ensemble échoue, sera-t-il annulé ? Vous pouvez faire un test vous-même.
Mono-thread, donc chaque commande est atomique. La cohérence et l'isolation sont destinées aux transactions. Les transactions Redis sont exécutées en encapsulant un groupe de commandes ensemble, elles sont donc isolées car elles bloquent les autres. Quant à l'exécution des commandes, quant à la cohérence. , si le test que vous effectuez ci-dessus est annulé, alors il est cohérent, s'il n'est pas annulé, alors il n'est pas cohérent.