redis进阶-事务管理

事务命令

MULTI    开启事务

WATCH    监控一个或多个key

UNWATCH    取消监控

EXEC    提交事务

DISCARD    取消事务

事务原理

先将事务的所有命令发送给redis,redis将这些命令放入等待执行的队列中,然后再让redis用EXEC命令依次执行这些命令,EXEC命令的返回值就是所有命令执行结果的返回值集合

错误处理

如果一个事务中的某个命令出错,那么如何处理?

1、语法错误

只要有一个语法错误的命令,redis直接返回错误,连语法正确的命令也不执行(2.6.5版本之前不会忽略语法正确的命令)

2、运行错误

这种错误在实际执行之前是无法发现的,所以错误的命令依然会被执行

redis事务没有回滚功能,需要自己收拾烂摊子

WATCH命令

可以监控一个或多个键,一旦其中有一个键被修改,之后的事务就不会执行,监控一直持续到EXEC命令,监控不能保证另一个客户端不修改这个键值

Jedis
Jedis jedis = new Jedis("127.0.0.1", 6379);
		String res = jedis.select(1);
		
		String res1 = jedis.watch("name","age");
		//开启事务
		Transaction transaction = jedis.multi();
		
		Response<String> res2 = transaction.set("name", "yuanyuan");
		Response<String> res3 = transaction.set("age", "20");
		
		//String res4 = transaction.discard();
        //提交事务
		List<Object> list = transaction.exec();
		jedis.unwatch();

 

上一篇:Azkaban的安装


下一篇:Docker(17)- docker exec 命令详解