博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
商品秒杀,防并发解决思路
阅读量:6503 次
发布时间:2019-06-24

本文共 1294 字,大约阅读时间需要 4 分钟。

我们在做电商项目的时候,经常会遇到抢购秒杀的问题,综合来说主要是两个问题

一,高并发情况下对数据库产生的压力

二,如何避免超卖(库存< 0)的情况。

针对这两个问题来谈下解决思路

一,缓解数据库压力 用 缓存就可以解决 例如redis,memecache 等 就不在多说了。

二,解决这个问题有几种思路(推荐4redis)

1、将库存 goods_store 设置为 unsigned 则当小于0的时候则update失败

sql = update goods set goods_store=goods_store-1 where goods_store>0 and goods_id=11111

2、利用flock 文件排它锁

$fp = fopen('flock.txt', 'w+');

if (!flock($fp, LOCK_EX | LOCK_NB)) {

     echo '系统繁忙稍后再试';

    die;

}

下单.....

减库存......

3、使用数据库悲观锁(数据库开销比较大)

mysql_query('BEGIN');

$sql = 'select goods_store from goods where goods_id=11111 for update';

$res = mysql_query($sql, $conn);

$row = mysql_fetch_assoc($res,);

if ($row['goods_store'] > 0){

$sql2 = 'update goods set good_store=goods_store-1 where goods_id=11111';

        ........

}

4、使用redis队列,因为pop操作是原子性的,即使很多用户到达也会依次执行,推荐使用(数据库悲观锁和flock在高并发情况下性能会下降很多)

①将库存存入redis

$amount = 100;

$redis = new Redis();

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

$result = $redis->llen('goods_expensive');//查询已经消费掉的库存

$count = $amount - $result;//剩余库存

for($i=0; $i < $count; $i++){

    $redis->lpush('goods_store',1);//遍历存入list

}

echo $redis->llen('goods_store');

②在下单前先判断库存量

$count=$redis->lpop('good_store');

if(!$count){

    die('没有库存了');

}

$sql = update goods set goods_store=goods_store-1 where goods_id=11111;

库存减少成功.....

转载于:https://www.cnblogs.com/ngx171/p/8579249.html

你可能感兴趣的文章
android单位转换小程序,微信小程序中rpx与rem单位转换
查看>>
ps切图教程 android,PS前端切图完整教程
查看>>
html显示服务器状态,显示服务器时间并一直显示(html代码)
查看>>
在线html代码优化,网站seo优化html代码方法
查看>>
HTML如何把输入框变成必填值,required输入框为必填项
查看>>
html定位有几种,POSITION定位有哪几种?各有什么特点?
查看>>
背锅侠逆袭之路
查看>>
演示:使用协议分析器取证IPv6的报文结构
查看>>
oracle 11gr2 rac中的4种IP解说
查看>>
为什么你找不到工作?
查看>>
20 个免费的 jQuery 的工具提示插件:
查看>>
汇编语言的应用
查看>>
device platform 相应的表
查看>>
php des 加密解密实例
查看>>
【Mac】Mac键盘实现Home, End, Page UP, Page DOWN
查看>>
实战使用Axure设计App,使用WebStorm开发(1) – 用Axure描述需求
查看>>
安德鲁斯----多媒体编程
查看>>
swift版的元组
查看>>
[zz]在linux中出现there are stopped jobs 的解决方法
查看>>
Delphi下实现全屏快速找图找色 一、数据提取
查看>>