对付商品抢购等并发场景下,可能会涌现超卖的征象,这时就须要办理并发所带来的这些问题了。
在PHP措辞中并没有原生的供应并发的办理方案,因此就须要借助其他办法来实现并发掌握。
方案一:利用文件锁排它锁
flock函数用于获取文件的锁,这个锁同时只能被一个线程获取到,其它没有获取到锁的线程要么壅塞,要么获取失落败。在获取到锁的时候,先查询库存,如果库存大于0,则进行下订单操作,减库存,然后开释锁。
方案二:利用MySQL数据库供应的悲观锁
Innodb存储引擎支持行级锁,当某行数据被锁定时,其他进程不能对这行数据进行操作。
先查询并锁定行:
select stock_num from table where id=1 for updateif(stock_num > 0){//下订单update table set stock_num=stock-1 where id=1}
方案三:利用行列步队
将用户的下单要求依次存入一个行列步队中,后台用一个单独的进程处理行列步队中的下单要求。
方案四:利用Redis
redis的操作都是原子性的,可以将商品的库存存入redis中,下单之前对库存进行decr操作,如果返回的值大于即是0等可以下单,否则不能下单,这种办法效率较高。
if(redis->get('stock_num') > 0){ stock_num = redis->decr('stock_num') if(stock_num >= 0){ //下订单 }else{ //库存不敷 }}else{//库存不敷}
以上便是php并发处理的几种方法的详细内容,更多请关注其它干系文章!
更多技巧请《转发 + 关注》哦!