国产+高潮+在线,国产 av 仑乱内谢,www国产亚洲精品久久,51国产偷自视频区视频,成人午夜精品网站在线观看

如何控制指定哪個進程來接收客戶端連接?

dignfei
use Workerman\Worker;
require __DIR__.'/../vendor/autoload.php';
$worker = new Worker('http://0.0.0.0:2120');
$worker->count = 1;
$worker->onWorkerStart = function($worker)
{
    // 讀取數(shù)據(jù),需要5秒。
}
$worker->onMessage = function($connection, $data)
{
    global $worker;
    global $ppp ;
    $pid = pcntl_fork();
    if  ($pid==0) { //父進程會得到子進程pid號,子進程$pid是0
        $ppp = $pid;
        return;
    } else {
        $ppp = $pid;
    }
};
// 運行worker
Worker::runAll();

需求:我需要把大量數(shù)據(jù)讀取到內(nèi)存,供客戶端查詢,需要做到0.2s內(nèi)響應(yīng)。數(shù)據(jù)同時在不斷更新,每5秒又要重新去讀取數(shù)據(jù)。
請問這個可以怎么實現(xiàn)?
我的不成熟想法:在onMessage中fork了一個進程,總共2個進程,
進程1個提供服務(wù),進程2去讀取最新數(shù)據(jù)
5秒后,進程1去讀取最新數(shù)據(jù),進程2提供服務(wù),
又5秒后,進程1提供服務(wù),進程2去讀取最新數(shù)據(jù)
問題是如何指定一個進程來處理客戶端請求?

3268 3 0
3個回答

th

為什么不設(shè)置$worker->count = 進程數(shù)???

  • dignfei 2020-03-14

    把數(shù)據(jù)讀取到PHP數(shù)組,會占用6000M內(nèi)存,用fork可以2個進程共用這部分內(nèi)存

six

感覺不用fork進程,開2個進程弄個鎖就搞定了。

use Workerman\Worker;
require __DIR__.'/../vendor/autoload.php';
$worker = new Worker('http://0.0.0.0:2120');
// 開啟2個進程
$worker->count = 2;
$data = [];
$worker->onWorkerStart = function($worker)
{
     // 定時每5秒去load以下數(shù)據(jù)
     Workerman\Lib\Timer::add(5, function(){
         // 獲取鎖,避免2個進程同時在load數(shù)據(jù)到內(nèi)存,沒有進程提供查詢服務(wù)
         $fp = fopen(__FILE__, 'r');
         if (!flock($fp, LOCK_EX | LOCK_NB )) {
             return;
         }
         global $data;
         $data = your_load_function();
         flock($fp, LOCK_UN);
     });
}
$worker->onMessage = function($connection, $msg)
{
    global $data;
    $key = $_GET['key'];
    $connecion->close(isset($data[$key]) ? $data[$key] : '');
};
// 運行worker
Worker::runAll();
  • dignfei 2020-03-14

    把數(shù)據(jù)讀取到PHP數(shù)組,會占用6000M內(nèi)存,用fork可以2個進程共用這部分內(nèi)存。開2個進程,就要占用2份內(nèi)存

  • dignfei 2020-03-14

    進程A讀取數(shù)據(jù),然后fork出進程b1去提供查詢服務(wù)。然后進程A繼續(xù)讀取新數(shù)據(jù),然后fork出進程b2去提供查詢服務(wù),然后把b1進程關(guān)閉。這樣比較好有2個優(yōu)點:1.只需要一份內(nèi)存 2.進程A每次只需要讀取增量的變化的數(shù)據(jù)

  • dignfei 2020-03-18

    有么有別的好的解決辦法??

  • six 2020-03-18

    加點硬件嘛,加個1G內(nèi)存很便宜。你想這么多天,人工成本早超過內(nèi)存了

dignfei

哪位大神能解答一下?????有什么好的解決辦法??

  • 暫無評論
年代過于久遠,無法發(fā)表回答
??