欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

PHP 進程池與輪詢調(diào)度算法實現(xiàn)多任務(wù)的示例代碼

 更新時間:2019年11月26日 09:03:35   作者:勺顛顛  
這篇文章主要介紹了PHP 進程池與輪詢調(diào)度算法實現(xiàn)多任務(wù)的示例代碼,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧

phper 請了解進程調(diào)度策略,CPU 時間片,進程控制【創(chuàng)建,銷毀,回收,進程信號】與及進程運行流程和基本的進程組,信號中斷原理,以及進程之間的關(guān)系。

關(guān)于進程的更多內(nèi)容可參考本人前面擼過的文章或是百度了解。

進程的通信:

匿名管道,命名管道,消息隊列,內(nèi)存共享,socketpair 請自行擼代碼測試哦

進程的調(diào)度算法:

輪詢,隨機分發(fā),計分板等策略或是搞個優(yōu)先極或是隊列,或是堆棧等基本的算法【自己去發(fā)揮哦】

進程池:

擼過 tcp 的話應(yīng)該知道要能處理多個客戶端,就得用 IO 復用技術(shù)【事件多路分發(fā)器】或是多進程以及多線程,每來一個客戶端就 fork 一個進程或是線程,那樣的話上下文切換成本特別高,所以咱們先創(chuàng)建好一組進程【進程池】,等客戶端連接上來的時候,通過某種算法【我們用的輪詢】來選擇某個進程投遞任務(wù)來干活,這樣的話就不用創(chuàng)建又銷毀來回折騰了,提升它的效率。下面是 PHP 代碼版本的實現(xiàn)

<?php
/**
 * Created by PhpStorm.
 * User: 1655664358@qq.com
 * Date: 2019/1/12
 * Time: 16:18
 */

$flag = 1;

class process
{
 public $pid;
 public $name;
 public $file;
 public $num;
}
class instance
{
 public $processIdx;
 public $proc = [];
 public $processNum;
}
function sigHandler($sigNo)
{
 global $flag;
 $flag = 0;
 echo "信號中斷處理".PHP_EOL;
}
function processPool(instance &$instance,$num)
{

 if (!$instance||$num==0){
  fprintf(STDERR,"%s","參數(shù)錯誤");
  return 1;
 }
 $instance->processIdx = 0;
 $instance->processNum = $num;

 pcntl_signal(SIGINT,'sigHandler');
 pcntl_signal(SIGTERM,'sigHandler');

 $process = new process();
 for ($i=1;$i<=$num;$i++){
  $instance->proc[$i] = clone $process;
  $instance->proc[$i]->file = $i;
  $instance->proc[$i]->pid = pcntl_fork();
  $instance->processIdx = $i;
  if ($instance->proc[$i]->pid<0){
   exit("進程創(chuàng)建失敗");
  }
  else if ($instance->proc[$i]->pid>0){
   //nothing
   continue;
  }else{

   worker($instance);
  }
 }
 master($instance);
 $exitProcess= [];
 while (1){
  for ($i=1;$i<=$num;$i++){
  //非阻塞方式回收子進程
   pcntl_waitpid($instance->proc[$i]->pid,$status,WNOHANG);
   if ($status){
    $exitProcess[] = $instance->proc[$i]->pid;
    fwrite(STDOUT,"worker#".$instance->proc[$i]->pid."-".$status,30);
   }
  }
  if (count($exitProcess)==$instance->processNum){
   exit(0);
  }
  usleep(1000);

 }

}
//簡單的輪詢算法 自己可以用隊列,隨機,鏈表,棧鏈,二叉樹啥的折騰
function roundRobin(&$instance,$roll)
{
 /** @var instance $instance */
 return $instance->proc[$roll%$instance->processNum+1];
}

function master(&$instance)
{

 /** @var instance $instance */
 fprintf(STDOUT,"master 進程 %d\n",$instance->processIdx);
 global $flag;
 $roll = 0;
 while ($flag){
  pcntl_signal_dispatch();
  /** @var process $process */
  $process = roundRobin($instance,$roll++);
  echo "輪詢的進程:".$process->pid.PHP_EOL;
  $file = $process->file;
  posix_mkfifo($file,0666);
  $fd = fopen($file,"w");
  fwrite($fd,"hi",2);
  sleep(1);

 }
 for ($i=1;$i<=$instance->processNum;$i++){
  posix_kill($instance->proc[$i]->pid,9);
 }
 fprintf(STDOUT,"master shutdown %d\n",$instance->processIdx);
}
function getProcess(&$instance)
{
 /** @var instance $instance */
 return $instance->proc[$instance->processIdx];
}
function worker(&$instance)
{
 /** @var process $process */
 $process = getProcess($instance);
 while (1){
  $file = $process->file;
  posix_mkfifo($file,0666);
  $fd = fopen($file,"r");
  $content = fread($fd,10);
  fprintf(STDOUT,"worker#%d讀取的內(nèi)容:%s file=%d\n",posix_getpid(),$content,$file);
 }
 exit(0);
}

$instance = new instance();
processPool($instance,5);

效果

以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • Yii2 中實現(xiàn)單點登錄的方法

    Yii2 中實現(xiàn)單點登錄的方法

    這篇文章主要介紹了Yii2 中實現(xiàn)單點登錄的方法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-03-03
  • 詳解Yii2 定制表單輸入字段的標簽和樣式

    詳解Yii2 定制表單輸入字段的標簽和樣式

    本篇文章主要介紹了 Yii2 定制表單輸入字段的標簽和樣式,Yii2中對于表單和字段的支持組件為ActiveForm和ActiveField,有興趣的可以了解一下。
    2017-01-01
  • PHPCMS2008廣告模板SQL注入漏洞修復

    PHPCMS2008廣告模板SQL注入漏洞修復

    PHPCMS2008由于廣告模塊取referer不嚴,導致一處sql注入漏洞.這篇文章主要介紹了PHPCMS2008廣告模板SQL注入漏洞的相關(guān)資料,需要的朋友可以參考下
    2016-10-10
  • php實現(xiàn)產(chǎn)品加入購物車功能(1)

    php實現(xiàn)產(chǎn)品加入購物車功能(1)

    這篇文章主要為大家詳細介紹了php實現(xiàn)產(chǎn)品加入購物車功能,具有一定的參考價值,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-03-03
  • PHP 二維數(shù)組和三維數(shù)組的過濾

    PHP 二維數(shù)組和三維數(shù)組的過濾

    本文給大家介紹PHP 二維數(shù)組和三維數(shù)組的過濾,涉及到php三維數(shù)組變二維數(shù)組的相關(guān)知識,本文介紹的非常詳細,具有參考借鑒價值,感興趣的朋友一起學習吧
    2016-03-03
  • Laravel 5框架學習之向視圖傳送數(shù)據(jù)

    Laravel 5框架學習之向視圖傳送數(shù)據(jù)

    本文向大家展示的是Laravel5框架學習系列的第三篇文章,給大家講解的是如何向視圖傳送數(shù)據(jù),從無到有,十分細致,有需要的小伙伴可以參考下。
    2015-04-04
  • YII2自動登錄Cookie總是失效的解決方法

    YII2自動登錄Cookie總是失效的解決方法

    這篇文章主要給大家介紹了關(guān)于YII2自動登錄Cookie總是失效的解決方法,文中給出了詳細的解決方法,對遇到這個問題的朋友們具有一定的參考學習價值,需要的朋友們下面來一起看看吧。
    2017-06-06
  • php中stream(流)的用法

    php中stream(流)的用法

    Stream是PHP開發(fā)里最容易被忽視的函數(shù)系列(SPL系列,Stream系列,pack函數(shù),封裝協(xié)議)之一,但其是個很有用也很重要的函數(shù)。Stream可以翻譯為“流”,下面是使用方法
    2014-03-03
  • PHP設(shè)計模式之數(shù)據(jù)訪問對象模式(DAO)原理與用法實例分析

    PHP設(shè)計模式之數(shù)據(jù)訪問對象模式(DAO)原理與用法實例分析

    這篇文章主要介紹了PHP設(shè)計模式之數(shù)據(jù)訪問對象模式(DAO)原理與用法,結(jié)合實例形式分析了PHP數(shù)據(jù)訪問對象模式的概念、原理、用法及操作注意事項,需要的朋友可以參考下
    2019-12-12
  • PHP多線程批量采集下載美女圖片的實現(xiàn)代碼(續(xù))

    PHP多線程批量采集下載美女圖片的實現(xiàn)代碼(續(xù))

    之前寫過一篇《PHP批量采集下載美女圖片》文中主要采用file_get_content做采集圖片,今天發(fā)現(xiàn)采集了400張圖片 居然需要70分鐘以上,真是難以忍受
    2013-06-06

最新評論