zoukankan      html  css  js  c++  java
  • php 利用flock来处理并发数据处理

    利用flock()函数对文件进行加锁(排它锁),实现并发按序进行。
    flock(file,lock,block)有三个参数。

    • file:已经打开的文件
    • lock:锁的类型
      LOCK_SH:共享锁(读锁)
      LOCK_EX:独占锁定(排它锁,写锁)
      LOCK_UN:解锁
      LOCK_NB:如果希望在文件锁定时阻塞进程,那么需要加上该参数
    • block:设置为true的时候,锁定文件时,会阻止其他进程
      下面是一个demo:

    阻塞模式(后面的进程会一直等待前面的进程执行完毕)

    $product_id = 1;//获取产品id
    $file = fopen('./lock/lock'.$product_id.'.txt', 'w');
    //加锁
    if(flock($file,LOCK_EX)){
        $number=Db::table('specification')->field('inventory')->where('specification_id','=',1)->find(); // 计数器
        if($number['inventory']>=1){
            //处理订单
            Db::table('specification')->where('specification_id','=',1)->dec('inventory')->update();
            flock($file, LOCK_UN);//释放锁
            fclose($file);
            echo json(['code'=>200,'result'=>'购买成功'])->getContent();die;
        }else{
            flock($file, LOCK_UN);//释放锁
            fclose($file);
            \exception('库存不足',500);
        }
    }
    

    非阻塞模式(只要当前文件有锁存在,那么直接返回)

    $product_id = 1;//获取产品id
    $file = fopen('./lock/lock'.$product_id.'.txt', 'w');
    //加锁
    if(flock($file,LOCK_EX|LOCK_NB)){
        $number=Db::table('specification')->field('inventory')->where('specification_id','=',1)->find(); // 计数器
        if($number['inventory']>=1){
            //处理订单
            Db::table('specification')->where('specification_id','=',1)->dec('inventory')->update();
            flock($file, LOCK_UN);//释放锁
            fclose($file);
            echo json(['code'=>200,'result'=>'购买成功'])->getContent();die;
        }else{
            flock($file, LOCK_UN);//释放锁
            fclose($file);
            \exception('库存不足',500);
        }
    }else{
            \exception('系统繁忙,请稍后再试',500);
    }
    

    来源:https://www.kancloud.cn/mr_y/wechat/1332950

  • 相关阅读:
    用弦截法求解方程的根
    Fibonacci_array
    爱你所爱,行你所行
    Visual Studio安装Visual Assist的办法(兼容VS2010至VS2017)
    对集合类型属性的实体类的查询集的封装
    简单购物选择案例--纯js代码
    静态json数据表格渲染展示
    js之全选,反选,全不选案例
    常见IO流简介
    JDBC一般流程
  • 原文地址:https://www.cnblogs.com/fogwang/p/15730472.html
Copyright © 2011-2022 走看看