事务要么同时成功,要么同时失败,原子性。(关系型事务库才会保证原子性)
redis事务本质:一组命令的集合,一个事务的所有命令都会被序列化,在事务执行过程中,会按照顺序执行!一次性,顺序性,排他性,执行一系列的命令!
注意:redis单条命令式保存原子性的,但是事务不保证原子性。redis事务没有隔离级别的概念!所有的命令在事务中,并没有直接被执行,只有发起执行命令的时候才会执行!Exec Redis的单条命令是保存原子性的,但是事务不保证原子性。
redis的事务
·开启事务()
·命令入队()
·执行事务()
锁:redis可以实现乐观锁
正常执行事务
127.0.0.1:6379> multi. #开启事务
OK
127.0.0.1:6379(TX)> set key1 v1。 #命令入队
QUEUED
127.0.0.1:6379(TX)> set key2 v2
QUEUED
127.0.0.1:6379(TX)> get key2
QUEUED
127.0.0.1:6379(TX)> set key3 v3
QUEUED
127.0.0.1:6379(TX)> exec。 #执行事务
- OK
- OK
- “v2”
- OK
放弃事务:
127.0.0.1:6379> multi
OK
127.0.0.1:6379(TX)> set k1 v1
QUEUED
127.0.0.1:6379(TX)> set k2 v2
QUEUED
127.0.0.1:6379(TX)> discard #放弃事务
OK
127.0.0.1:6379> get k2
(nil)
###############################
处理错误
编译型异常,运行时异常
针对运行时异常(1/0),如果事务队列中存在语法性,那么命令执行的时候,其他命令是可以正常执行的。只有错误命令会抛出异常。
127.0.0.1:6379> set key1 v1
OK
127.0.0.1:6379> multi
OK
127.0.0.1:6379(TX)> incr key1
QUEUED
127.0.0.1:6379(TX)> set ke v2
QUEUED
127.0.0.1:6379(TX)> set keys v3
QUEUED
127.0.0.1:6379(TX)> exec
- (error) ERR value is not an integer or out of range
- OK
- OK
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)