国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專欄INFORMATION COLUMN

PHP 利用文件鎖處理高并發

calx / 3709人閱讀

利用flock()函數對文件進行加鎖(排它鎖),實現并發按序進行。

flock(file,lock,block)有三個參數。

file : 已經打開的文件

lock : 鎖的類型

LOCK_SH : 共享鎖定(讀鎖)

LOCK_EX : 獨占鎖定(排它鎖,寫鎖)

LOCK_UN : 解鎖

LOCK_NB : 如果希望在文件鎖定時阻塞進程,那么需要加上該參數

block : 設置為true的時候,鎖定文件時,會阻止其他進程

下面是一個簡單demo
    /**
     *  阻塞模式(后面的進程會一直等待前面的進程執行完畢)
     */
    public function crateOrder()
    {
        $file = fopen(__DIR__."/lock.txt","w+");
        //加鎖
        if(flock($file,LOCK_EX))
        {
            //TODO 執行業務代碼
            flock($file,LOCK_UN);//解鎖
        }
        //關閉文件
        fclose($file);
    }

      /**
     *  非阻塞模式(只要當前文件有鎖存在,那么直接返回)
     */
    public function crateOrder()
    {
        $file = fopen(__DIR__."/lock.txt","w+");
        //加鎖
        if(flock($file,LOCK_EX|LOCK_NB))
        {
            //TODO 執行業務代碼
            flock($file,LOCK_UN);//解鎖
        }
        else
        {
            //TODO 執行業務代碼 返回系統繁忙等錯誤提示

        }
        //關閉文件
        fclose($file);

    }
小提示:在執行fclose()的時候文件也會自動解鎖,所以可以省略解鎖的代碼

文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。

轉載請注明本文地址:http://specialneedsforspecialkids.com/yun/29371.html

相關文章

  • PHP利用Mysql解決并發

    摘要:前面寫過利用文件鎖來處理高并發的問題的,現在我們說另外一個處理方式,利用的鎖來解決高并發的問題先看沒有利用事務的時候并發的后果創建庫存管理表創建訂單管理表測試代碼我們預置庫存是十個,然后執行測試查看結果 前面寫過利用文件鎖來處理高并發的問題的,現在我們說另外一個處理方式,利用Mysql的鎖來解決高并發的問題 先看沒有利用事務的時候并發的后果 創建庫存管理表 CREATE TABLE `...

    Coly 評論0 收藏0
  • Mysql的機制與PHP文件處理并發簡單思路

    摘要:以購買商品舉例從數據庫獲取庫存的數量。這里暫時就不測試了,下面會針對并發的處理給出測試結果。第二種方案,使用的文件鎖。特點當調用鎖一個文件時,如果沒有獲取鎖,直接返回,不會出現阻塞。的表鎖和的文件鎖在應對并發數量上也有差別,自己可以多測試。 以購買商品舉例: ① 從數據庫獲取庫存的數量。② 檢查一下庫存的數量是否充足。③ 庫存的數量減去買家購買的數量(以每個用戶購買一個為例)。④ 最后...

    sunsmell 評論0 收藏0
  • PHP面試題

    摘要:質量高在設計時,可重用現有的,在以前的項目的領域中已被測試過的類使系統滿足業務需求并具有較高的質量。代碼塊捕獲異常,并創建一個包含異常信息的對象。這樣可以解決超賣的問題,但是會導致文件得開銷很大。 6.你們公司是使用什么框架? 答:我們公司采用的是TP框架,運用的mysql+apache+php進行開發,因為TP框架是一個免費開源的,輕量級的php開發框架,而且是我們中國人自己開發的,...

    ls0609 評論0 收藏0

發表評論

0條評論

最新活動
閱讀需要支付1元查看
<