現在已經有很多完善的開源rpc架構了,如果要理解程式如何能高效穩定運行,理解rpc建立的過程很有必要,自建過程大致可以分成兩部分,通訊部分和協調部分。
通訊部分有服務端和客戶端,服務端監聽約定好的端口,等待連接,客戶端建立與服務端的連結。為了資訊高效傳輸,資料需要序列化之後傳輸,接收後反序列化。
有了以上兩個需求,總結一些服務端和客戶端的功能。
服務端功能可以有:監聽埠、回應連線請求、接收資料包、解析資料包、呼叫回應方法、組裝請求處理結果資料包、傳送結果資料包;客戶端功能可以有:建立連接、組裝資料、發送資料包、接收處理結果資料包、解析資料包回傳結果。
到此一個簡單的rpc功能就完成了。
作為生產層級的產品,只有核心通訊功能是不夠用的,還需要協調管理功能,讓功能穩定且有效率地運作。
需要連線池加快連結建立的速度,叢集部署的消費者需要負載平衡,叢集中的節點需要路由管理,需要隨時維護服務狀態,剔除錯誤節點,需要優雅關閉,避免重啟導致訊息遺失,需要過載保護,丟棄超時請求等等。
好了綜上所述,再總結一下消費者和生產者的功能需求。
消費者可以有:連線管理、負載平衡、請求路由、逾時處理、健康檢查;生產者可以有:執行緒池、逾時丟棄、優雅關閉、過載保護。
以上是總結的自建rpc需要的功能,有遺漏歡迎補充。
#相關推薦:《java影片教學》
以上是自建RPC都需要哪些功能?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

MantisBT
Mantis是一個易於部署的基於Web的缺陷追蹤工具,用於幫助產品缺陷追蹤。它需要PHP、MySQL和一個Web伺服器。請查看我們的演示和託管服務。

PhpStorm Mac 版本
最新(2018.2.1 )專業的PHP整合開發工具

MinGW - Minimalist GNU for Windows
這個專案正在遷移到osdn.net/projects/mingw的過程中,你可以繼續在那裡關注我們。 MinGW:GNU編譯器集合(GCC)的本機Windows移植版本,可自由分發的導入函式庫和用於建置本機Windows應用程式的頭檔;包括對MSVC執行時間的擴展,以支援C99功能。 MinGW的所有軟體都可以在64位元Windows平台上運作。

mPDF
mPDF是一個PHP庫,可以從UTF-8編碼的HTML產生PDF檔案。原作者Ian Back編寫mPDF以從他的網站上「即時」輸出PDF文件,並處理不同的語言。與原始腳本如HTML2FPDF相比,它的速度較慢,並且在使用Unicode字體時產生的檔案較大,但支援CSS樣式等,並進行了大量增強。支援幾乎所有語言,包括RTL(阿拉伯語和希伯來語)和CJK(中日韓)。支援嵌套的區塊級元素(如P、DIV),

ZendStudio 13.5.1 Mac
強大的PHP整合開發環境