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

用户投稿 122 0

关于“PHP秒杀怎么做”的问题,小编就整理了【2】个相关介绍“PHP秒杀怎么做”的解答:

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

面试高级php工程师,一般会问到哪些问题?

高并发大访问量的mysql优化,服务器优化?

字段建索引、主从数据库、读写分离、表分区、负载均衡。

linux的慢查询日志会记录mysql的超时查询sql语句,定期察看进行优化。

2.大访问量下秒杀模块程序怎么设计,如果使用mysql会有多卖的情况,就是订单超过库存。

将订单数据缓存到内存,如果用数据库直接崩掉,毫无悬念的。

3.缓存的使用

能用静态的用静态,不能静态的用内存缓存,例如memcache、redis,不能缓存的用数据库。

4.session可不可以跨域?怎么跨域?

将PHP session机制重写(PHP提供),将session存储在memcache或者数据库就可以跨域了。

另外session能以三种方式存储,文件、数据库、缓存。

5.了不了解非关系型数据库?

mongodb

6.会不会写shell脚本以及linux的操作

还会问一下时下流行的东西,比如做没做过微信开发,例如微信支付开发、APP移动开发,等等问题。

问的核心东西都是围绕这些转的,如果有笔试会让你写sql,php功能(例如冒泡排序等排序),还有逻辑题。

我当初面试了很多,这是一个我的面试经验的总结,纯手打忘采纳。

到此,以上就是小编对于“PHP秒杀怎么做”的问题就介绍到这了,希望介绍关于“PHP秒杀怎么做”的【2】点解答对大家有用。

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