PHP Redis - 事务

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);

 

posted @ 2022-02-25 10:26  邈宇  阅读(415)  评论(0编辑  收藏  举报