概念请参考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)
代码1:for循环批量插入100W数据<?php set_time_limit(0); $servername = "localhost"; $username = "root"; $password ...
在一个正式项目中操作人员提交239个产品信息进行保存,但是系统却提示没有提交239个产品,于是开启错误信息,显示如下:Warning: Unknown: Input variables exceeded 1000. To incr...
(1).config.php 配置文件<?php /** * RabbitMQ_Config */ $config = [ 'host' => ...
elasticsearch的操作都是基于http协议的,已经有现成的php类库,composer安装即可。{ "require": { &...
在调用微信code换openid的接口curl报错curl Received HTTP code 403 from proxy after CONNECT,错误码56。可以看到是curl的代理有问题。然后我自己电脑设置代理去访问curl请求的地址,的确也返回了403,说明代理不允许访问这个地址,联系...
安装php-redis扩展提示No releases available for package我直接去php官网下载redis扩展.tgz文件,然后直接用pecl安装本地文件pecl install ./redis.tgz...