对付商品抢购等并发场景下,可能会涌现超卖的征象,这时就须要办理并发所带来的这些问题了。

在PHP措辞中并没有原生的供应并发的办理方案,因此就须要借助其他办法来实现并发掌握。

方案一:利用文件锁排它锁

php并发php并发处置的几种办法 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并发处理的几种方法的详细内容,更多请关注其它干系文章!

更多技巧请《转发 + 关注》哦!