本篇文章給大家帶來的內容是關于swoole_process父子進程管道通信的代碼示例,有一定的參考價值,有需要的朋友可以參考一下,希望對你有所幫助。
話不多說直接上代碼
創建的子進程:
- public function __construct()
- {
- $this->redis = Container::get(SwooleRedis::class);//獲取異步redis獲取更高性能
- $this->process = new swoole_process(function (swoole_process $process) {
- return $this->process($process);
- }, false, SOCK_DGRAM);
- $this->process->name('Test_Gateway');
- $this->process->useQueue();
- $this->process->start();//啟動子進程
- }
- /**
- * 子進程處理邏輯
- * @param swoole_process $process
- */
- private function process(swoole_process $process)
- {
- $client = new swoole_client(SWOOLE_SOCK_TCP, SWOOLE_SOCK_ASYNC); //異步非阻塞
- $client->on("connect", function (swoole_client $cli) use ($process) {
- $process->write('connected');
- });
- $client->on("receive", function (swoole_client $cli, $data) use ($process) {
- $process->write($data);
- });
- $client->on("error", function (swoole_client $cli) use ($process) {
- $process->write('error');
- });
- $client->on("close", function (swoole_client $cli) use ($process) {
- $process->write('close');
- });
- if ($client->connect('127.0.0.1', 90, -1)) {
- } else {
- $process->write('網關連接失敗');
- }
- swoole_event_add($process->pipe,
- function ($pipe) use ($process, $client) {//讀取父進程管道消息
- $client->send($process->read());
- });
- }
父進程onWorkerStart:
- /**
- * @param swoole_server $serv
- * @param $worker_id
- */
- public function onWorkerStart(/swoole_server $serv, $worker_id)
- {
- if ($worker_id === 0) {
- swoole_timer_tick(1000, function () {
- $this->process->write('ping');
- });
- $process = $this->process;
- swoole_event_add($process->pipe,
- function ($pipe) use ($process) {//獲取子進程的管道消息
- echo "子進程消息:" . $process->read() . PHP_EOL;
- });
- }
- }
子進程的client客戶端可以忽略不計,本demo只是掩飾管道通信的例子
使用管道就不可以使用消息隊列:$process_push()和$process->pop();
理論上在父子進程各注冊一個event_loop即可實現一邊發消息一邊接收
其他的后續補充
新聞熱點
疑難解答