swoole process use queue example
admin
2023-06-16 17:42:02
0

server:

class Server
{
   private $_serv = null;

   private $_workers = [];

   private $_worker_num = 2;

   public function __construct()
   {
       $this->_serv = new swoole_server('127.0.0.1', 9501);

       $this->_serv->on('start', array($this, 'onStart'));
       $this->_serv->on('workerstart', array($this, 'onWorkerStart'));
       $this->_serv->on('connect', array($this, 'onConnect'));
       $this->_serv->on('receive', array($this, 'onReceive'));
       $this->_serv->on('close', array($this, 'onClose'));

       $this->_serv->start();
   }

   public function onStart($serv)
   {
       echo "start \n";
   }

   public function onWorkerStart($serv, $worker_id)
   {
       echo "worker start\n";
   }
   
   public function onConnect($serv, $fd, $from_id )
   {
       echo "connect..\n";
   }

   public function onReceive(swoole_server $serv, $fd, $from_id, $data)
   {

       for ($i = 0; $i < $this->_worker_num ;$i++) {
           $process = new swoole_process(array($this, 'onProcess'), false, false);
           $process->useQueue();
           $pid = $process->start();
           echo $pid;
           $this->_workers[$pid] = $process;
       }

       foreach ($this->_workers as $pid => $worker) {
           echo $process->push("hello worker[{$pid}]\n");
           sleep(2);//停2秒,不然主进程pop时 获取消息太快,而阻塞状态了,push完给子进程消息,子进程逻辑还没处理完
           //(1)不加这停两秒时,可能主进程马上pop时,队列是空的,主进程阻塞状态了,下面子进程只能pop和push一次,再pop时也阻塞状态了
           //客户端再发send消息时,服务器不响应,除非新client进来,发send,主进程阻塞取消了,第一个客户端又可以发send消息了,第二个客户端
           //发send消息时,服务端不响应,这种情况发生了
           
$result = $process->pop();//默认模式下,如果队列中没有数据,pop方法会阻塞等待
           echo "From worker: $result\n";//这里主进程,接受到的子进程的数据
       }

       for($i = 0; $i < $this->_worker_num; $i++)
       {
           $ret = swoole_process::wait();
           $pid = $ret['pid'];
           unset($this->_workers[$pid]);
           echo "Worker Exit, PID=".$pid.PHP_EOL;
       }

   }

   public function onProcess($worker)
   {
       $msg_status = $worker->statQueue();
       if($msg_status['queue_num'] > 0)
       {
           $recv = $worker->pop();

           echo "FROM master {$recv}\n";
           $worker->push("heheh parent");//子进程处理完逻辑,不是马上push数据给主进程  sleep(2)
       }
       $worker->exit(0);

   }

   public function onClose($serv, $fd, $from_id)
   {
       echo "close.\n";
   }
}

new Server();


client:

$cli = new Swoole_client(SWOOLE_SOCK_TCP);

$cli->connect('127.0.0.1', 9501, 1);

fwrite(STDOUT, '输入消息:');
$msg = trim(fgets(STDIN));

echo $cli->send($msg);

echo $cli->recv()."\n";


相关内容

热门资讯

AI支付时代要来了吗?支付宝A... 【大河财立方 记者 杨霄 王宇】5月26日,在支付宝AI支付生态大会上,支付宝宣布,“AI支付”已完...
毫厘间的山河:0.001%背后... 元素周期表的版图上,锌,是一块古老而平凡的疆域。但当它的纯度跃升至99.998%时,这块金属便被赋予...
朝鲜进行新型武器系统试射 当地时间5月26日,朝鲜导弹总局和国防科学院进行轻型多用途导弹发射系统和多管战术巡航导弹武器系统试验...
原创 华... 华为各大产品全面发展,而且是多系列多版本,其中手机/笔记本均拥有4个系列,平板/手表均拥有6个系列,...
俄法院裁定:立即赔偿俄约200... △俄罗斯中央银行(资料图)当地时间5月26日,俄罗斯莫斯科仲裁法院批准俄央行的申请,将对欧洲清算银行...
特朗普:内阁会议将由戴维营改至... 当地时间5月26日,美国总统特朗普在社交平台发文称,由于预计次日天气状况不佳,原定在戴维营举行的内阁...
江苏省内首次!变电站装上了“智... 扬子晚报网5月26日讯(记者 刘丽媛)5月25日,江苏南京220千伏光华变电站完成一项特殊改造——在...
NbS暑期学校广州开班!国内外... 南都讯 记者莫郅骅 5月26日,2026基于自然的解决方案(NbS)暑期学校在广州开班。该活动由自然...
一场训练营,孵化112个创新项... AI赋能民生、科创点亮青春! 从课堂灵感孵化的音乐记忆AI工具 到深耕水产行业的智能经营助手 一批贴...
潮评丨原创精神无法“一键生成” 潮新闻客户端 评论员 高路 图源:央视新闻。 继“查重”以后,检测AIGC(人工智能生成内容)率也...