日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 人文社科 > 生活经验 >内容正文

生活经验

Thrift架构与使用方法

發布時間:2023/11/28 生活经验 32 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Thrift架构与使用方法 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

Thrift是由Facebook為“大規??缯Z言服務開發”而開發的,現在是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?提供了對編碼后的消息數據進行不同方式網路傳輸的傳輸工具

總結

以上是生活随笔為你收集整理的Thrift架构与使用方法的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。