最新php 文件鎖大全

            網絡整理 分享 時間: 收藏本文

            最新php 文件鎖大全

            在日常的學習、工作、生活中,肯定對各類范文都很熟悉吧。寫范文的時候需要注意什么呢?有哪些格式需要注意呢?這里我整理了一些優秀的范文,希望對大家有所幫助,下面我們就來了解一下吧。

            php 文件鎖篇一

            下面是由百分網小編為大家整理的php文件鎖與進程鎖的實現,喜歡的可以收藏一下!了解更多詳情資訊,請關注應屆畢業生考試網!

            借用swoole的服務器/客戶端與多進程機制對鎖進行說明.

            這里只針對php的鎖機制進行說明,由于sql的鎖與其作用方式和應用場景不同,將作另行說明.

            1.文件鎖

            flock()

            fclose()

            swoole_lock()

            文件鎖的可能應用場景為:

            1.限制并發多進程或多臺服務器需要對同一文件進行訪問和修改;

            2.對參與文件i/o的進程隊列化和人為阻塞;

            3.在業務邏輯中對文件內容進行守護;

            下面是文件鎖c/s通訊機制下的使用,已經省略了具體的通訊過程,如有需要請移步swoole異步任務隊列

            server(服務器通訊過程已略):

            //監聽數據發送事件

            $serv->on('receive', function ($serv, $fd, $from_id, $data) {

            $serv->send($fd, "serverend");

            $p_file = "";

            var_dump(file_get_contents($p_file));

            });

            client1(服務器通訊過程已略):

            $s_recv = "ww";

            $p_file = "";

            $o_file = fopen($p_file,'w+');// flock()加鎖方式:

            flock($o_file,lock_ex);// // swoole加鎖方式:

            // $lock = new swoole_lock(swoole_filelock, $p_file);

            // $lock->lock();

            fwrite($o_file, 'ss' . $s_recv);

            sleep(30);// 兩種解鎖方式

            // flock($o_file, lock_un);

            // $lock->unlock();

            client2(服務器通訊過程已略):

            $s_recv = "xx";

            $p_file = "";

            $o_file = fopen($p_file,'w+');// flock()加鎖方式:

            flock($o_file,lock_ex);//

            // swoole加鎖方式:

            // $lock = new swoole_lock(swoole_filelock, $p_file);

            // $lock->lock();

            fwrite($o_file, 'ss' . $s_recv);// 兩種解鎖方式

            // flock($o_file, lock_un);

            // $lock->unlock();

            結果:

            client2被阻塞了30s,直到client1執行結束才對文件進行了一次寫入;

            [l0.16@4 m29.5% c30s04] $ php

            需要注意的是:

            1.無論是flock()還是swoole提供的swoole_lock(),都有在進程結束時自動解鎖的機制,所以在demo中即使不進行手動解鎖也能正常運行,因此這里在第一個client中執行了sleep()暫停函數來觀察文件鎖的效果;

            ()的標準釋放方式為flock($file,lock_un);, 但是個人喜歡fclose(),永絕后患;

            2.進程鎖

            與文件鎖不同的是,進程鎖并不用于阻止對文件的i/o,而是用于防止多進程并發造成的預期之外的后果.所以需要在多進程并發時將其隊列化,即在某進程的關鍵邏輯執行結束前阻塞其他并發進程的邏輯執行.

            實現思路有幾種:

            1.利用flock()文件鎖,創建一個臨時lock文件,使用lock_nb模擬阻塞或非阻塞流,再在進程內部使用判定條件控制邏輯執行;

            非阻塞模型demo:

            $p_file = "";

            $o_file = fopen($p_file, 'w+');// 如果臨時文件被鎖定,這里的flock()將返回false

            if (!flock($o_file, lock_ex + lock_nb)) {

            var_dump('process locked');

            }else { ? ?// 非阻塞模型必須在flock()中增加lock_nb參數

            // 當然,這里取消lock_nb參數就是阻塞模型了

            flock($o_file, lock_ex + lock_nb);

            var_dump('process locking'); ? ?// 模擬長時間的執行操作

            sleep(10);

            }

            2.利用swoole提供的共享內存,緩存方法或通信方法在不同的.進程中傳遞一個全局變量,進程獲取該變量的狀態后使用判定條件控制邏輯執行;

            傳遞變量的方法很多,這里只提供一個思路,就以memcached為例;

            阻塞模型demo:

            // 初始化memcached$memcached = new memcache;

            $memcached->connect("localhost", 11211);// 獲取用來做狀態判定的全局變量

            $s_flag = $memcached->get("flag");

            if (!$s_flag) {

            // 這里利用了memcached的過期時間作為演示,實際上業務處理完成后銷毀該變量即可

            $memcached->set("flag", "locked", 0, 10);

            main();

            }else {

            // 阻塞模型

            while ($s_flag == 'locked') {

            var_dump('process locked, retrying...');

            // 設置重試時間, 避免過于頻繁的操作嘗試

            sleep(1); ? ? ? ?// 更新狀態變量

            $s_flag = $memcached->get("flag");

            }

            // // 非阻塞模型

            // if ($s_flag == 'locked') {

            // ? ? var_dump('process locked, suspended');

            // ? ? die();

            // }

            main();

            }// 模擬業務主函數function main() {

            var_dump('process running'); ?// 業務執行結束后回收memcached

            // $memcached->delete("flag");

            }

            這里需要注意的是:

            hed的過期時間不可少于程序運行的實際時間,因此建議稍微長一點,邏輯執行結束后進行回收;

            2.在非阻塞模型中,若狀態被判定為false,應該將進程中止或block,避免業務邏輯的繼續執行;

            3.在實際應用中,設置一個重試時間很有必要,這樣可以很大程度上減少針對memcached的大量i/o并發,減輕服務器壓力;

            s("content_relate");

            【php文件鎖與進程鎖的實現】相關文章:

            php文件鎖與進程鎖

            09-06

            linux新手教程之創建鎖文件的方法

            08-21

            php中讀取大文件實現方法

            09-05

            php實現大文件上傳源代碼

            08-29

            php中讀取大文件實現方法詳解

            09-23

            php文件是什么 如何打開php文件

            08-27

            鑰匙鎖車內怎么辦

            11-11

            php文件怎么操作

            09-07

            php文件緩存的性能測試

            09-10

            主站蜘蛛池模板: 精品一区中文字幕| 国产第一区二区三区在线观看| 日韩美女在线观看一区| 国产一区二区在线观看app| 中文字幕av一区| 国产免费一区二区三区| 国产精品视频一区二区三区无码| 青娱乐国产官网极品一区 | 一区二区三区免费在线视频| 性色AV一区二区三区天美传媒| 亚洲A∨无码一区二区三区| 综合人妻久久一区二区精品 | 99久久精品国产免看国产一区| 日韩一区二区三区视频| 国产精品盗摄一区二区在线| 国内精品一区二区三区最新 | 综合人妻久久一区二区精品| 国产精品 一区 在线| 国产一区二区三区福利| 国产AV一区二区精品凹凸| 国产精品电影一区二区三区| 日韩有码一区二区| 午夜精品一区二区三区在线视| 无码人妻一区二区三区在线水卜樱| 日本中文字幕在线视频一区| 亚洲国产激情一区二区三区| 国产激情一区二区三区 | 综合久久久久久中文字幕亚洲国产国产综合一区首 | 亚洲国产激情在线一区| 3D动漫精品啪啪一区二区下载| 亚洲天堂一区二区三区四区| 色窝窝无码一区二区三区色欲| 丰满人妻一区二区三区视频53 | 日韩精品人妻一区二区中文八零 | 无码一区二区三区亚洲人妻| 国产亚洲综合精品一区二区三区| 精品无码一区二区三区水蜜桃 | 无码人妻精一区二区三区| 日韩a无吗一区二区三区| 中文字幕亚洲一区| 69福利视频一区二区|