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的調用實作。
總結使用方法如下:
- 使用Thrift的IDL編寫接口定義檔案
- 使用Thrift的編譯器生成特定語言的接口程式源代碼
- 編寫用戶端和服務端程式
Thrift的架構
- TProtocol提供了對基礎類型資料進行不同方式編碼的消息協定工具
- TTransport提供了對編碼後的消息資料進行不同方式網路傳輸的傳輸工具