Redis 事务踩坑

栏目: 数据库 · 发布时间: 7年前

内容简介:`从monitor 日志 可以看到开发中 PHP demo 操作

Redis 测试 Demo

<?php
# 原子操作  redis  事务
$redis = new \Redis();
$redis->connect('127.0.0.1', '6379', 3);

// 监控key WATCH  事务开启前监控key
$redis->WATCH('test_hash');

// 开启事务
$redis->MULTI();

// 事务内执行写操作
$redis->set('test_hash', 2);

$redis->set('test_hash', 1);

// 提交事务
$redis->exec();

// 回滚事务
// $redis->discard();

redis 事务 需要通过 redis-cli monitor 监控中看到 正常提交流程

`

1544372307.803143 [0 127.0.0.1:37532] "MULTI"
    1544372307.803225 [0 127.0.0.1:37532] "WATCH" "test_hash"
    1544372308.923998 [0 127.0.0.1:37502] "SET" "test_hash" "2"
    1544372312.803550 [0 127.0.0.1:37532] "SET" "test_hash" "1"
    1544372312.803566 [0 127.0.0.1:37532] "EXEC"
    1544372318.742735 [0 127.0.0.1:37502] "get" "test_hash"

如果事务中 中间监控key 发生变动 就会变成

1544372363.760832 [0 127.0.0.1:37556] "WATCH" "test_hash"
    1544372363.760935 [0 127.0.0.1:37556] "MULTI"
    1544372366.129051 [0 127.0.0.1:37502] "set" "test_hash" "2"
    1544372368.761290 [0 127.0.0.1:37556] "EXEC"

从monitor 日志 可以看到 37556 端口实例监控 test_hash , 37502 端口实例修改了 test_hash exec 仍然提交 但中间没有提交

"SET" "test_hash" "2"
    "SET" "test_hash" "1"

开发中 PHP demo 操作 exec 返回

成功 :

array(2) {
  [0] =>
  bool(true)
  [1] =>
  bool(true)
}

失败 :

bool(false)

还有个小彩蛋 测试了下 将 test_hash 类型改外其他 hash 或 zset 事务提交也会成功, 成功后将test_hash 改成 string 类型了. 这又点霸道了.

测试环境 redis 3.2.12

最后更新于 2018-12-09 16:49:47 并被添加「redis」标签,已有 1 位童鞋阅读过。


以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

Google總部大揭密

Google總部大揭密

史蒂芬.李維 / 陳重亨 / 財信 / 2011-11

∣如果有一天,Google的搜尋引擎突然故障 ∣GMAIL信件全數消失 ∣Google Maps、Google Docs、Google行事曆等所有雲端服務全面停擺 ∣我們該怎麼辦?! 歷史上像Google如此成功,且廣受推崇的企業可沒幾家。它改變了網路的使用方式,也成了我們生活不可或缺的一部分。這到底是怎麼辦到的? 《連線》雜誌資深主筆史蒂芬.李維史無前例同時取得LS......一起来看看 《Google總部大揭密》 这本书的介绍吧!

在线进制转换器
在线进制转换器

各进制数互转换器

Markdown 在线编辑器
Markdown 在线编辑器

Markdown 在线编辑器

RGB CMYK 转换工具
RGB CMYK 转换工具

RGB CMYK 互转工具