概念请参考w3school文章: redis watch ,redis exec (看完基本秒懂)
(1)基本事务:
//连接本地的 Redis 服务 $redis = new Redis(); $redis->connect('127.0.0.1', 6379); //开启事务 $redis->multi(); //操作key $redis->flushAll(); $redis->incr('user_id'); $redis->incr('user_id'); $redis->incr('user_id'); $ping = $redis->ping(); //执行事务 $result = $redis->exec(); if ($result) { echo '执行事务成功' . PHP_EOL; } else { echo '执行事务失败' . PHP_EOL; } //打印执行事务可以看到所有的执行结果 var_dump($result);
输出结果:
array(5) { [0]=> bool(true) [1]=> int(1) [2]=> int(2) [3]=> int(3) [4]=> string(5) "+PONG" }
(2).监视key执行事务(Watch 命令用于监视一个(或多个) key ,如果在事务执行之前这个(或这些) key 被其他命令所改动,那么事务将被打断)
<?php exec('chcp 65001'); //连接本地的 Redis 服务 $redis = new Redis(); $redis->connect('127.0.0.1', 6379); //清空redis $redis->flushAll(); //操作的redisKey $key = 'user_id'; //监视key $redis->watch($key); //开启事务 $redis->multi(); //睡眠点时间,手动开一个终端也去操作这个key sleep(60); //操作key $redis->incr($key); //执行事务 $result = $redis->exec(); if ($result) { echo '执行事务成功' . PHP_EOL; } else { echo '执行事务失败' . PHP_EOL; } //打印执行事务可以看到所有的执行结果 var_dump($result);
执行结果:
执行事务失败 bool(false)
在一个正式项目中操作人员提交239个产品信息进行保存,但是系统却提示没有提交239个产品,于是开启错误信息,显示如下:Warning: Unknown: Input variables exceeded 1000. To incr...
php官方的超全局变量$_SERVER['PHP_SELF']也能直接获取,只不过如果url参数太多也会获取。下面提供一个方法获取/* * 获取当前PHP文件名称 */ if (!function_exists('phpself...
ThinkPHP中有一个debug调试功能,能输出报错文件的信息,并能看到这个函数被哪些函数调用,从框架的启动开始记录,特别方便调试。于是研究了下它的底层给予了实现。<?php //--框架核心--Start //框架内置错误处理 function errDealWith($er...
参数中包含gb2312的字符串,返回结果是false或者null(不同PHP版本具有差异性)代码:<?php $dbms = 'mysql'; $host = '192.168.8.8'; $dbName =&n...
<?php /** * daemonize让当前脚本为守护进程执行 * @param string $callback 匿名函数 */ function daemonize($callback) {...
自己的composer已经发布到packagist,但是无法使用composer require easy-task/easy-task来安装,只能在配置文件使用如下方式安装:"require": { "easy...