Redis 事务可以一次执行多个命令, 并有两个重要的保证:
① 事务是一个单独的隔离操作:事务中的所有命令都会序列化、按顺序地执行。事务在执行的过程中,不会被其他客户端发送来的命令请求所打断。
② 事务是一个原子操作:事务中的命令要么全部被执行,要么全部都不执行。
一个事务从开始到执行会经历以下三个阶段:开始事务;命令入队;执行事务。
1. 监视/取消监视 一个(或多个) key(Watch/Unwatch)
// 监视一个(或多个) key ,如果在事务执行之前这个(或这些) key 被其他命令所改动,那么事务将被打断 $redis->watch(array(key1, key2)); // 取消 WATCH 命令对所有 key 的监视 // 如果watch监视之后执行了exec或discard,会自动取消监视,不必再unwatch $redis->unwatch(array(key1, key2));
2. 开始事务(Multi)
// 标记一个事务块的开始 $redis->multi();
3. 执行事务(Exec)
// 执行事务块内的所有命令 // 事务块内所有命令的返回值,按命令执行的先后顺序排列。 当操作被打断时,返回空值 nil 。 $redis->exec();
4. 取消事务(Discard)
// 取消事务,放弃执行事务块内的所有命令。 $redis->discard();
完整示例:
<?php try { //连接本地的 Redis 服务 $redis = new Redis(); $redis->connect('127.0.0.1', 6379); } catch (Exception $e){ echo $e->getMessage(); die; } $key1 = 'page'; $key2 = 'page2'; $redis->set($key1, '520'); $redis->set($key2, '521'); try { //监视一个(或多个)key,如果在事务执行之前这个(或这些) key 被其他命令所改动,那么事务将被打断 $redis->watch(array($key1, $key2)); //模拟监视 key 被打断 //$redis->set($key1, '12345'); $redis->multi(); $redis->set($key1, '1123'); $redis->set($key2, '2123'); //执行事务块内的所有命令 $status = $redis->exec(); //失败则取消事务 if (!$status) { $redis->discard(); } } catch (Exception $e){ echo $e->getMessage(); die; } echo $redis->get($key1) . '-' .$redis->get($key2);
本文为崔凯原创文章,转载无需和我联系,但请注明来自冷暖自知一抹茶ckhttp://www.cksite.cn