标签:事务 执行 Redis key1 redis key key2 PHP
Redis 事务可以一次执行多个命令, 并有两个重要的保证:
① 事务是一个单独的隔离操作:事务中的所有命令都会序列化、按顺序地执行。事务在执行的过程中,不会被其他客户端发送来的命令请求所打断。
② 事务是一个原子操作:事务中的命令要么全部被执行,要么全部都不执行。
一个事务从开始到执行会经历以下三个阶段:开始事务;命令入队;执行事务。
// 监视/取消监视 一个(或多个) key(Watch/Unwatch)
// 监视一个(或多个) key ,如果在事务执行之前这个(或这些) key 被其他命令所改动,那么事务将被打断 $redis->watch(array(key1, key2)); // 取消 WATCH 命令对所有 key 的监视 // 如果watch监视之后执行了exec或discard,会自动取消监视,不必再unwatch $redis->unwatch(array(key1, key2));
开始事务(Multi)
// 标记一个事务块的开始 $redis->multi();
执行事务(Exec)
// 执行事务块内的所有命令 // 事务块内所有命令的返回值,按命令执行的先后顺序排列。 当操作被打断时,返回空值 nil 。 $redis->exec();
取消事务(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);
标签:事务,执行,Redis,key1,redis,key,key2,PHP 来源: https://www.cnblogs.com/zydr/p/15927179.html
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。