Thrift架構與使用方法

Thrift是由Facebook爲“大規模跨語言服務開發”而開發的,現在是Apache軟件基金會的開源項目。

Thrift實現了一種接口描述語言和二進制通訊協議,用來定義和創建跨語言的服務。它被當作一個RPC框架來使用。

Thrift支持的語言和特性

如果現在要實現一個除法divide的RPC接口服務:

float divide(1:int num1, 2:int num2=1) => InvalidOperation

如何使用Thrift來進行實現呢?

Thrift的基礎庫程序中已經提供了用於RPC通訊的底層基本消息協議和傳輸工具,也就是調用雙方如何傳輸str、int、float等不同基本類型的數據無需我們自己再實現了。

但是對於不同的RPC接口是由不同個數不同類型的參數構成的,如上述divide服務就是有兩個int類型的調用參數和float類型或InvalidOperation異常的返回值構成,也就是說發起調用時我們需要傳遞兩個int類型的數據,調用完成返回值的時候,我們需要傳遞float類型或InvalidOperation異常,這些就需要我們利用Thrift提供的基礎庫自己寫代碼來實現。每個RPC接口服務都要定義出來,才能完成整個RPC調用。

若想調用雙方使用不同的編程語言開發,即在不同的語言程序間完成RPC調用,那每個RPC接口服務都需要在調用方和被調用方使用不同的語言來定義。

上面的過程實際上是簡單的重複工作。Thrift允許我們使用一種獨立於任何編程語言的新的語言來定義接口服務,通常把這種語言成爲接口定義語言(IDL,Interface Definition Language),我們使用Thrift的IDL將接口定義在一個文本文件中(通常使用.thrift後綴名,成爲接口定義文件),然後使用Thrift提供的編譯器(compiler)根據這個文件生成所需要的語言的程序源代碼。\

 

生成得到不同接口的程序代碼後,我們再編寫客戶端的調用代碼和服務端的接口功能實現代碼及啓動代碼,就可完成Thrift RPC的調用實現。

總結使用方法如下:

  1. 使用Thrift的IDL編寫接口定義文件
  2. 使用Thrift的編譯器生成特定語言的接口程序源代碼
  3. 編寫客戶端和服務端程序

Thrift的架構

 

  • TProtocol 提供了對基礎類型數據進行不同方式編碼的消息協議工具
  • TTransport 提供了對編碼後的消息數據進行不同方式網路傳輸的傳輸工具
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章