swoole進程間如何通信

来源:https://www.cnblogs.com/heyue0117/archive/2019/12/02/11973746.html

Swoole進程間通信的方式 管道pipe 管道用於進程之間的數據交互,Linux系統本身提供了pipe函數用於創建一個半雙工通信管道。半雙工的通信方式中數據只能單向流動(一端只讀一端只寫),只能在具有親緣關係(父子進程)的進程之間使用。 管道是進程間通信IPC中最基礎的方式,管道有兩種類型分別是命 ...


 

 

Swoole進程間通信的方式

管道pipe

管道用於進程之間的數據交互,Linux系統本身提供了pipe函數用於創建一個半雙工通信管道。半雙工的通信方式中數據只能單向流動(一端只讀一端只寫),只能在具有親緣關係(父子進程)的進程之間使用。

管道是進程間通信IPC中最基礎的方式,管道有兩種類型分別是命名管道、匿名管道。

匿名管道:專門用於具有血緣關係的進程之間,完成數據傳遞。命名管道:可以用在任何兩個進程之間,Swoole中的管道都是匿名管道。

在Swoole中利用eventfd和UnixSock封裝了兩種管道,使得進程之間的通信更加靈活。

Swoole的Process模塊內置了管道的方式用於進程間通信,在構建Process實例時只要開啟了$pipe_type選項,Swoole底層會自動創建一個管道,這裡需要說明的時,雖然名字上叫做管道,但實際上在新版Swoole中底層通信是通過UnixSock實現的,所以並不是真正意義上的Linux Pipe。

創建進程

 

 

管道類型$pipe_type可分為三種:

0表示不創建管道

1表示創建SOCK_STREAM類型的管道

2表示創建SOCK_DGRAM類型的管道

當啟用$redirect_stdin_stdout後,$pipe_type選項將忽略用戶參數,強製為1。

管道描述符

當進程被fork出來後,父進程和子進程中的Process對象會被設置上一個名為pipe的成員變數,存放著底層UnixSocket的描述符,父進程和子進程可以通過這個管道描述符來發送數據,也可以直接調用Process提供的read/write介面來收發數據。

 

 

管道讀寫

swoole_process->write(string $data) 向進程的管道中寫入數據

swoole_process->read(int $buffer_size = 8192) 從進程的管道中讀取數據

以上就是swoole進程間如何通信的詳細內容,更多請關註我吧

有需要學習交流的友人請加入Swoole交流群的咱們一起,有問題一起交流,一起進步!前提是你是學技術的。感謝閱讀!

點此加入該群​jq.qq.com

 


您的分享是我們最大的動力!

更多相關文章
  • 第1期(20191202) 文章 1. "A short guide to the structure and internals of the " Erlang distributed messaging facility. Erlang分散式啟動流程源碼閱讀指南: 節點啟動時通過 互相發現彼此。 ...
  • from tkinter import * def callback(*args): xl.set(xE.get()) print("改變的數據:",xE.get()) root = Tk() root.title("tkinter的trace()變動追蹤") xE = StringVar() en ...
  • 在workerman中會經常使用,我們先寫一個回調函數,當某個行為被觸發後使用該函數處理相關邏輯。 在PHP中最常用的幾種回調寫法如下 匿名函數做為回調 匿名函數(Anonymous functions),也叫閉包函數(closures),允許臨時創建一個沒有指定名稱的函數。最經常用作回調函數(ca ...
  • 1 為何要適用線程池 首先我們知道線程對於操作系統來說是一種 珍貴的資源 ,像我們如果每次使用到的時候手動創建,線程執行完 方法後又自動關閉,下次用的時候還得手動創建,這樣無論對於操作系統還是我們來說都是一種 時間 和 資源 的浪費,所以我們可以選擇維護一些線程,這些線程在執行完任務之後繼續執行其他 ...
  • [TOC] ajax結合sweetalert使用 點擊下載 "Bootstrap sweetalert" 一通CV大法: 這裡有個問題,發現漢字被擋住了。。。 通過谷歌瀏覽器的檢查,查看html元素修改,加上樣式即可: 後端views.py bulk_create批量插入數據 在django向資料庫 ...
  • golang和swoole區別 開發效率 Go語言是本質上是靜態語言,開發效率稍差,但性能更強,更適合底層軟體的開發 Swoole使用PHP語言,動態腳本語言,開發效率最佳,更適合應用軟體的開發 IO模型 go語言使用單線程eventloop處理IO事件,多線程實現協程調度,執行用戶層代碼 swoo ...
  • 例如:[4,6,2,2,6,4,4,4]→[4,4,4,4,6,6,2,2] 一: 先統計每個元素出現次數,然後按照出現次數進行逆向排序。 二:通過比較元組(-元素頻率,元素index值) ...
  • 在 Swoole 官網的自我介紹是“面向生產環境的 PHP 非同步網路通信引擎”,首先 Swoole 它是一個網路應用的開發工具,它支持 Http、TCP、UDP、WebSocket。 Swoole 和我們傳統的 PHP 開發差別是有的,需要理解的概念也是有的。使用目前一些基於 Swoole 的框架開 ...
一周排行
  • .NET 走向開源,MIT許可協議。 微軟為了推動.NET開源社區的發展,2014年聯合社區成立了.NET基金會。 一年前 .NET 基金會完成第一次全面改選,2014年 .NET基金會的創始成員中有六位創始人,均非微軟公司員工,隨著微軟的收購動作,Miguel 也成了微軟員工,Migel一直在努力 ...
  • 在這篇文章中,我將帶領大家詳細學習ASP.NET Core 中的Main方法。在這篇文章中,我將向大家詳細介紹下麵幾個問題:ASP.NET Core Main方法的重要性為什麼我們在ASP.NET Core中會有一個Main方法?當你運行一個ASP.NET Core應用程式的時候,背後發生了什麼?為... ...
  • IViewLocationExpander API ExpandViewLocations Razor視圖路徑,視圖引擎會搜索該路徑. PopulateValues 每次調用都會填充路由 項目目錄如下所示 創建區域擴展器,其實我並不需要多區域,我目前只需要達到一個區域中有多個文件夾進行存放我的視圖. ...
  • EF Core 數據變更自動審計設計 Intro 有的時候我們需要知道每個數據表的變更記錄以便做一些數據審計,數據恢復以及數據同步等之類的事情, EF 自帶了對象追蹤,使得我們可以很方便的做一些審計工作,每次變更發生了什麼變化都變得很清晰,於是就基於 EF 封裝了一層數據變更自動審計 使用效果 測試 ...
  • 在上一篇文章abp(net core)+easyui+efcore實現倉儲管理系統——入庫管理之六(四十二)中我們實現了新增入庫單的功能。結合之前的五篇文章,今天我們來測試一下入庫單新增功能。 ...
  • 這篇文章,我們一起學習ASP.NET Core InProcess Hosting.這篇文章主要討論下麵幾個觀點:CreateDefaultBuilder方法執行什麼任務?什麼是ASP.NET Core InProcess Hosting?怎麼使用InProcess hosting Model來托管... ...
  • 關於 Blazor Server Side 的開篇 , Blazor與 C/S , B/S 有什麼不一樣 , Blazor有什麼優缺點? ...
  • VS2019+MVC+EF6 CodeFirst 連接MySQL 1、準備環境(通過NuGet獲取) EntityFramework MySql.Data.Entity 安裝後確認 2、在MVC Model文件夾下添加一個學生類,後面用它通過[數據遷移]在MySQL中創建一個表 3、創建數據上下文 ...
  • 這篇文章,向大家介紹ASP.NET Core中的Kestrel Web伺服器。這篇文章主要討論下麵兩個重要的事情:什麼是Kestrel 伺服器?怎麼使用.NET Core CLI來運行ASP.NET Core應用程式?什麼是Kestrel伺服器? 我們已經知道ASP.NET Core是一個跨平臺的開... ...
  • 前言 回顧之前的兩篇Swagger做Api介面文檔,我們大體上學會瞭如何在net core3.1的項目基礎上,搭建一套自動生產API介面說明文檔的框架。 本來在Swagger的基礎上,前後端開發人員在開發生產期間,可以藉此進行更加便捷的溝通交流。可是總有些時候,遇到一些難纏的,又不講道理,偏偏覺得將 ...