Swoole 中涉及的一些基本概念

来源:https://www.cnblogs.com/a609251438/archive/2020/06/30/13215832.html
-Advertisement-
Play Games

IO(Input/Output,輸入輸出) 在電腦中,輸入 / 輸出(即 IO)是指信息處理系統(比如電腦)和外部世界(可以是人或其他信息處理系統)的通信。輸入是指系統接收的信號或數據,輸出是指從系統發出的數據或信號。由於程式和運行時數據是在記憶體中駐留,由 CPU 這個超快的計算核心來執行,涉及 ...


IO(Input/Output,輸入輸出)

在電腦中,輸入 / 輸出(即 IO)是指信息處理系統(比如電腦)和外部世界(可以是人或其他信息處理系統)的通信。輸入是指系統接收的信號或數據,輸出是指從系統發出的數據或信號。由於程式和運行時數據是在記憶體中駐留,由 CPU 這個超快的計算核心來執行,涉及到數據交換的地方,通常是磁碟、網路等,就會有 IO 產生。

同步 - 非同步

同步和非同步是一種消息通信機制 (synchronous communication/asynchronous communication),關註點在於 被調用者返回 和 結果返回 之間的關係, 描述對象是被調用對象的行為。

# 同步(Synchronous):在發出一個同步調用時,在沒有得到結果之前,該調用就不返回,等待返回結果才繼續執行後續的操作。

# 非同步( Asynchronous):發出調用,直接返回,不關心是否返回結果。非同步可以通過狀態、回調、 通知調用者結果,可以先去執行其他操作,然後等待通知再回來執行剛纔沒執行完的操作。
 

阻塞 - 非阻塞

阻塞和非阻塞是一種業務流程處理方式。關註點在於調用發生時 調用者狀態 和 被調用者返回結果 之間的關係。 描述的是等待結果時候調用者的狀態此時結果可能是同步返回的,也能是非同步返回。

# 阻塞( Blocking ):在結果返回之前,當前線程被掛起,後續代碼只有在結果返回後才能執行。

# 非阻塞( Nonblocking):在不能立刻獲取結果前,該調用不會阻塞當前線程。

同步阻塞 - 同步非阻塞

實際編程中,通過線程實現進程的同步非阻塞,通過協程實現線程的同步非阻塞。

# 同步阻塞:打電話問老闆有沒有某書(調用),老闆說查一下,讓你別掛電話(同步),你一直等待老闆給你結果,什麼事也不做(阻塞)。

# 同步非阻塞:打電話問老闆有沒有某書(調用),老闆說查一下,讓你別掛電話(同步),等電話的過程中你還一邊嗑瓜子(非阻塞)。

非同步阻塞 - 非同步非阻塞

 

# 非同步阻塞:打電話問老闆有沒有某書(調用),老闆說你先掛電話,有了結果通知你(非同步),你掛了電話後(結束調用), 除了等老闆電話通知結果,什麼事情也不做(阻塞)。

 

# 非同步非阻塞:打電話問老闆有沒有某書(調用),老闆說你先掛電話,有了結果通知你(非同步),你掛電話後(結束調用),一遍等電話,一遍嗑瓜子。(非阻塞)

 

IO 模型

5 種 I/O 模型:

  • 阻塞式 I/O
  • 非阻塞式 I/O
  • I/O 復用(select,poll,epoll…)
  • 信號驅動式 I/O(SIGIO)
  • 非同步 I/O(POSIX 的 aio_系列函數)

IO 模型的具體解釋可以參考 linux 五種 IO 模型

參考資源

 


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

-Advertisement-
Play Games
更多相關文章
  • 一、Socket 1.Socket構造方法 構造方法說明 Socket() 該創建的對象,沒有指定IP地址和埠號,意味著只創建了客戶端對象,並且沒有連接任何伺服器。通過該構造方法創建對象後還需要調用connect(SocketAddress endpoint)方法,才能完成與指定伺服器端的連接,其 ...
  • 現在距離 Python 3.9.0 的最終版本還有 3 個月,官方公佈的時間線是: 3.9.0 beta 4: Monday, 2020-06-29 3.9.0 beta 5: Monday, 2020-07-20 3.9.0 candidate 1: Monday, 2020-08-10 3.9. ...
  • 類載入運行的全過程 當用java命令運行某個main函數時,首先需要類載入器把主類載入到JVM記憶體中。 通過Java命令執行代碼的大致流程為 將編譯好的位元組碼class文件通過java命令,在win操作系統就是一個java.exe文件,這個文件底層是c++語言實現的,通過這個文件調用底層jvm.dl ...
  • mac 使用yarn brew install yarn 安裝全局vue-cli全家桶: yarn global add @vue/cli 驗證: node -v npm -v 打開界面 vue ui 本文由博客一文多發平臺 OpenWrite 發佈! ...
  • 前言 網路上的信息很多,有的時候我們需要關鍵字搜索才可以快速方便的找到我們需要的信息。今天我們實現搜索關鍵字爬取堆糖網上相關的美圖,零基礎學會通用爬蟲,當然我們還可以實現多線程爬蟲,加快爬蟲爬取速度 環境: windows pycharm python3 導入模塊 import urllib.par ...
  • 本文源碼:GitHub·點這裡 || GitEE·點這裡 一、服務間隔離 1、分散式結構 分散式系統架構的明顯特點,就是按照業務系統的功能,拆分成各種服務,每個服務下麵都有自己獨立的資料庫,以此降低業務間的耦合度,隔離不同的資料庫保證系統最大的穩定性等。 例如上圖是電商系統中經典的業務場景,訂單-倉 ...
  • clone 並導入源碼 本地啟動 NameServer 本地啟動 Broker 本地運行生產者與消費者代碼 完成上述步驟之後,RocketMQ的源碼環境就搭建完畢了,之後就可以在本地啟動以及收發消息,調試和分析RocketMQ的源碼了。 clone 並導入源碼 在 github 上選擇對應的的代碼 ...
  • 常用類 string類: 常量都是存在jvm,方法區的常量池當中 String str1 = "123"; String str2 = "123"; System.out.println(str1.equals(str2));//true System.out.println(str1 == str ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...