php redis 扩展,php使用redis怎么解决秒杀中的超卖问题?

用户投稿 111 0

关于“redis_php5.6_扩展”的问题,小编就整理了【2】个相关介绍“redis_php5.6_扩展”的解答:

php使用redis怎么解决秒杀中的超卖问题?

超卖问题的根本原因还是在于并发,服务端对于并发处理的能力不足造成了超卖问题;

应对高并发问题一方面要提高服务端的请求处理能力,比如使用redis的事务(witch+multi)来提高处理速度。

另一方面就是削峰;常见的方案是通过消息队列缓冲瞬时请求高峰;通过消息队列可以吧同步请求转换成异步推送通知,通过队列一端承接瞬时访问高峰,另一端则平滑地将消息推送出去,达到削峰目的。

个人见解,希望对您的问题有所帮助!

使用redis 的队列+watch解决,把秒杀商品放入队列,抢到则pop商品,队列用完,则停止抢购

<?php

header("content-type:text/html;charset=utf-8");

$redis = new redis();

$result = $redis->connect('127.0.0.1', 6379);

$mywatchkey = $redis->get("mywatchkey");

$rob_total = 100; //抢购数量

if($mywatchkey<$rob_total){

$redis->watch("mywatchkey");

$redis->multi();

//设置延迟,方便测试效果。

sleep(5);

//插入抢购数据

$redis->hSet("mywatchlist","user_id_".mt_rand(1, 9999),time());

$redis->set("mywatchkey",$mywatchkey+1);

set nx函数用法?

1. set nx函数是在Matlab中用于设置矩阵的元素值的函数。

2. 使用set nx函数可以方便地设置矩阵中某个元素的值,可以通过指定行列坐标或者线性索引来进行设置。

例如,set nx(A, 2, 3, 4)可以将矩阵A中第2行第3列的元素设置为4。

3. set nx函数还可以用于设置多个元素的值,可以通过指定多个行列坐标或者线性索引来进行设置。

此外,set nx函数还支持一些高级用法,例如可以设置矩阵的某个区域的值,或者可以使用函数句柄来进行设置。

在 Redis 里,所谓 SETNX,是「SET if Not eXists」的缩写,也就是只有不存在的时候才设置,可以利用它来实现锁的效果,不过很多人没有意识到 SETNX 有陷阱!

比如说:某个查询数据库的接口,因为调用量比较大,所以加了缓存,并设定缓存过期后刷新,问题是当并发量比较大的时候,如果没有锁机制,那么缓存过期的瞬间,大量并发请求会穿透缓存直接查询数据库,造成雪崩效应,如果有锁机制,那么就可以控制只有一个请求去更新缓存,其它的请求视情况要么等待,要么使用过期的缓存。

下面以目前 PHP 社区里最流行的 PHPRedis 扩展为例,实现一段演示代码:

<?php

$ok = $redis->setNX($key, $value);

if ($ok) {

$cache->update();

$redis->del($key);

}

?>

缓存过期时,通过 SetNX 获取锁,如果成功了,那么更新缓存,然后删除锁。看上去逻辑非常简单,可惜有问题:如果请求执行因为某些原因意外退出了,导致创建了锁但是没有删除锁,那么这个锁将一直存在,以至于以后缓存再也得不到更新。于是乎我们需要给锁加一个过期时间以防不测:

到此,以上就是小编对于“redis_php5.6_扩展”的问题就介绍到这了,希望介绍关于“redis_php5.6_扩展”的【2】点解答对大家有用。

抱歉,评论功能暂时关闭!