首先 Redis是支持一定事务能力的 NOSQL,在 Redis中使用事务,通常的命令组合是 watch…mutil…exec,也就是要在一个 Redis连接中执行多个命令,这时我们可以考虑使用 SessionCallback接口来达到这个目的。其中watch命令是可以监控Reds的一些键;mutil命令是开始事务,开始事务后,该客户端的命令不会马上被执行,而是存放在一个队列里,这点是需要注意的地方,也就是在这时我们执行一些返回数据的命令, Redis也是不会马上执行的,而是把命令放到一个队列里,所以此时调用 Redis的命令,结果都是返回null;exe命令的意义在于执行事务,只是它在队列命令执行前会判断被watch监控的 Redis的键的数据是否发生过变化(即使赋予与之前相同的值也会被认为是变化过),如果它认为发生了变化,那么 Redis就会取消事务,否则就会执行事务,Reds在执行事务时,要么全部执行,要么全部不执行,而且不会被其他客户端打断,这样就保证了 Redis事务下数据的一致性。 首先我们设置redisTemplate的key序列化器为StringSerializer,value暂时不进行设置(设置序列化的代码可以参考第一篇文章): @Test void redisTest3() { List list = (List) redisTemplate.execute((RedisOperations redisOperation) -> { redisOperation.opsForValue().set("k11", "11"); redisOperation.watch("k11"); redisOperation.