久久久久久久av_日韩在线中文_看一级毛片视频_日本精品二区_成人深夜福利视频_武道仙尊动漫在线观看

PHP 文件鎖與進(jìn)程鎖的使用示例

本篇文章主要介紹了PHP 文件鎖與進(jìn)程鎖的使用示例,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧

鑒于前面介紹了swoole,就借用swoole的服務(wù)器/客戶端與多進(jìn)程機(jī)制對(duì)鎖進(jìn)行說(shuō)明.

這里只針對(duì)PHP的鎖機(jī)制進(jìn)行說(shuō)明,由于SQL的鎖與其作用方式和應(yīng)用場(chǎng)景不同,將作另行說(shuō)明.

1.文件鎖

  • flock()
  • fclose()
  • swoole_lock()

文件鎖的可能應(yīng)用場(chǎng)景為:

1.限制并發(fā)多進(jìn)程或多臺(tái)服務(wù)器需要對(duì)同一文件進(jìn)行訪問(wèn)和修改;

2.對(duì)參與文件I/O的進(jìn)程隊(duì)列化和人為阻塞;

3.在業(yè)務(wù)邏輯中對(duì)文件內(nèi)容進(jìn)行守護(hù);

下面是文件鎖C/S通訊機(jī)制下的使用,已經(jīng)省略了具體的通訊過(guò)程

Server(服務(wù)器通訊過(guò)程已略):

//監(jiān)聽(tīng)數(shù)據(jù)發(fā)送事件
$serv->on('receive', function ($serv, $fd, $from_id, $data) {
  $serv->send($fd, "ServerEnd");

  $p_file = "locktest.txt";
  var_dump(file_get_contents($p_file));
});

Client1(服務(wù)器通訊過(guò)程已略):

$s_recv = "ww";

$p_file = "locktest.txt";

$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(服務(wù)器通訊過(guò)程已略):

$s_recv = "xx";

$p_file = "locktest.txt";

$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();

結(jié)果:

Client2被阻塞了30s,直到Client1執(zhí)行結(jié)束才對(duì)文件進(jìn)行了一次寫入;

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

需要注意的是:

1.無(wú)論是flock()還是swoole提供的swoole_lock(),都有在進(jìn)程結(jié)束時(shí)自動(dòng)解鎖的機(jī)制,所以在demo中即使不進(jìn)行手動(dòng)解鎖也能正常運(yùn)行,因此這里在第一個(gè)Client中執(zhí)行了sleep()暫停函數(shù)來(lái)觀察文件鎖的效果;

2.flock()的標(biāo)準(zhǔn)釋放方式為flock($file,LOCK_UN);, 但是個(gè)人喜歡fclose(),永絕后患;

2.進(jìn)程鎖

與文件鎖不同的是,進(jìn)程鎖并不用于阻止對(duì)文件的I/O,而是用于防止多進(jìn)程并發(fā)造成的預(yù)期之外的后果.所以需要在多進(jìn)程并發(fā)時(shí)將其隊(duì)列化,即在某進(jìn)程的關(guān)鍵邏輯執(zhí)行結(jié)束前阻塞其他并發(fā)進(jìn)程的邏輯執(zhí)行.

實(shí)現(xiàn)思路有幾種:

1.利用flock()文件鎖,創(chuàng)建一個(gè)臨時(shí)lock文件,使用LOCK_NB模擬阻塞或非阻塞流,再在進(jìn)程內(nèi)部使用判定條件控制邏輯執(zhí)行;

非阻塞模型demo:

$p_file = "locktest.txt";
$o_file = fopen($p_file, 'w+');

// 如果臨時(shí)文件被鎖定,這里的flock()將返回false
if (!flock($o_file, LOCK_EX + LOCK_NB)) {
  var_dump('Process Locked');
}
else {
  // 非阻塞模型必須在flock()中增加LOCK_NB參數(shù)
  // 當(dāng)然,這里取消LOCK_NB參數(shù)就是阻塞模型了
  flock($o_file, LOCK_EX + LOCK_NB);
  var_dump('Process Locking');
  // 模擬長(zhǎng)時(shí)間的執(zhí)行操作
  sleep(10);
}

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

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

阻塞模型demo:

// 初始化memcached
$memcached = new Memcache;
$memcached->connect("localhost", 11211);

// 獲取用來(lái)做狀態(tài)判定的全局變量
$s_flag = $memcached->get("flag");

if (!$s_flag) {
  // 這里利用了memcached的過(guò)期時(shí)間作為演示,實(shí)際上業(yè)務(wù)處理完成后銷毀該變量即可
  $memcached->set("flag", "locked", 0, 10);
  main();
}
else {
  // 阻塞模型
  while ($s_flag == 'locked') {
    var_dump('Process locked, retrying...');
    // 設(shè)置重試時(shí)間, 避免過(guò)于頻繁的操作嘗試
    sleep(1);
    // 更新?tīng)顟B(tài)變量
    $s_flag = $memcached->get("flag");
  }
  // // 非阻塞模型
  // if ($s_flag == 'locked') {
  //   var_dump('Process locked, suspended');
  //   die();
  // }
  main();
}

// 模擬業(yè)務(wù)主函數(shù)
function main() {
  var_dump('Process Running');
  // 業(yè)務(wù)執(zhí)行結(jié)束后回收memcached
  // $memcached->delete("flag");
}

這里需要注意的是:

1.memcached的過(guò)期時(shí)間不可少于程序運(yùn)行的實(shí)際時(shí)間,因此建議稍微長(zhǎng)一點(diǎn),邏輯執(zhí)行結(jié)束后進(jìn)行回收;

2.在非阻塞模型中,若狀態(tài)被判定為false,應(yīng)該將進(jìn)程中止或block,避免業(yè)務(wù)邏輯的繼續(xù)執(zhí)行;

3.在實(shí)際應(yīng)用中,設(shè)置一個(gè)重試時(shí)間很有必要,這樣可以很大程度上減少針對(duì)memcached的大量I/O并發(fā),減輕服務(wù)器壓力;

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持。

【網(wǎng)站聲明】本站除付費(fèi)源碼經(jīng)過(guò)測(cè)試外,其他素材未做測(cè)試,不保證完整性,網(wǎng)站上部分源碼僅限學(xué)習(xí)交流,請(qǐng)勿用于商業(yè)用途。如損害你的權(quán)益請(qǐng)聯(lián)系客服QQ:2655101040 給予處理,謝謝支持。

相關(guān)文檔推薦

這篇文章主要介紹了PHP有序表查找之插值查找算法,簡(jiǎn)單分析了插值查找算法的概念、原理并結(jié)合實(shí)例形式分析了php實(shí)現(xiàn)針對(duì)有序表插值查找的相關(guān)操作技巧,需要的朋友可以參考下
下面小編就為大家分享一篇ThinkPHP整合datatables實(shí)現(xiàn)服務(wù)端分頁(yè)的示例代碼,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
下面小編就為大家分享一篇PHP實(shí)現(xiàn)APP微信支付的實(shí)例講解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
這篇文章主要介紹了PHP實(shí)現(xiàn)的多維數(shù)組排序算法,結(jié)合實(shí)例形式對(duì)比分析了php針對(duì)多維數(shù)組及帶有鍵名的多維數(shù)組進(jìn)行排序相關(guān)操作技巧與注意事項(xiàng),需要的朋友可以參考下
這篇文章主要為大家詳細(xì)介紹了php結(jié)合ajaxuploadfile實(shí)現(xiàn)無(wú)刷新文件上傳功能,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
本篇文章給大家詳細(xì)介紹了PHP開(kāi)發(fā)接口使用RSA進(jìn)行加密解密方法,對(duì)此有興趣的朋友可以學(xué)習(xí)下。
主站蜘蛛池模板: 亚洲精品二三区 | 国产日韩视频 | 免费三级黄 | 国产综合在线视频 | 免费精品视频 | 福利视频一区二区 | 青青伊人久久 | 男女免费网站 | 操操日 | 日日骚网| 精品久久久久久久久久久久久久 | 成人在线免费电影 | 免费观看一级黄色录像 | 精品国产乱码久久久久久影片 | 本地毛片 | 成人h免费观看视频 | 精品视频免费 | 国产美女在线观看 | 欧美日韩国产欧美 | 精品福利视频一区二区三区 | 成人亚洲性情网站www在线观看 | 久久国产精品视频免费看 | 国产精品片aa在线观看 | 久久精品免费一区二区三 | 国产高清一区二区三区 | 国产成人精品一区二区三区四区 | 涩在线 | 中文字幕乱码亚洲精品一区 | 久久久精品一区 | 一区二区三区视频 | 亚洲在线一区二区 | 正在播放国产精品 | 蜜桃视频在线观看www社区 | 日本不卡一区二区 | 国产成人精品午夜 | 欧美国产日韩在线观看成人 | 国产一区二区三区在线视频 | 韩三级在线观看 | 日韩高清成人 | 久久久久久亚洲欧洲 | 亚洲精品视频免费观看 |