亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 學院 > 開發設計 > 正文

Thrift框架介紹

2019-11-11 07:47:51
字體:
來源:轉載
供稿:網友
本文轉自:http://dongxicheng.org/search-engine/thrift-framework-intro/和http://www.cnblogs.com/buptlyn/p/4459577.html

1、前言

Thrift是一個跨語言的服務部署框架,最初由Facebook于2007年開發,2008年進入Apache開源項目。

Thrift特征如下:

1)Thrift有自己的跨機器通信框架,并提供一套庫

2)Thrift是一個代碼生成器,按照它的規則,可以生成多種編程語言的通信過程代碼

Thrift通過一個中間語言(IDL, 接口定義語言)來定義RPC的接口和數據類型,然后通過一個編譯器生成不同語言的代碼(目前支持C++,java, Python, php, Ruby, Erlang, Perl, Haskell, C#, Cocoa, Smalltalk和OCaml),并由生成的代碼負責RPC協議層和傳輸層的實現。

2、架構

1).thrift文件定義數據結構和服務接口

2)代碼生成器生成若干符合約定通信格式的代碼

3)thrift應用框架:包括thrift自身提供的庫函數

4)第三方庫:按照運行的模式,生成的代碼中可能需要調用第三方庫

Thrift實際上是實現了C/S模式,通過代碼生成工具將接口定義文件生成服務器端和客戶端代碼(可以為不同語言),從而實現服務端和客戶端跨語言的支持。用戶在Thirft描述文件中聲明自己的服務,這些服務經過編譯后會生成相應語言的代碼文件,然后用戶實現服務(客戶端調用服務,服務器端提服務)便可以了。其中PRotocol(協議層, 定義數據傳輸格式,可以為二進制或者xml等)和transport(傳輸層,定義數據傳輸方式,可以為TCP/ip傳輸,內存共享或者文件共享等)被用作運行時庫。

3、 支持的數據傳輸格式、數據傳輸方式和服務模型

(1)支持的傳輸格式:是對傳輸協議的封裝,傳輸采用二進制、XML或text來表示信息

TBinaryProtocol – 二進制格式.

TCompactProtocol – 壓縮格式

TJSONProtocol – JSON格式

TSimpleJSONProtocol –提供JSON只寫協議, 生成的文件很容易通過腳本語言解析。

TDebugProtocol – 使用易懂的可讀的文本格式,以便于debug

(2) 支持的數據傳輸方式:信息的傳輸渠道以及讀寫方式

TSocket -阻塞式socker

TFramedTransport – 以frame為單位進行傳輸,非阻塞式服務中使用。

TFileTransport – 以文件形式進行傳輸。

TMemoryTransport – 將內存用于I/O. java實現時內部實際使用了簡單的ByteArrayOutputStream。

TZlibTransport – 使用zlib進行壓縮, 與其他傳輸方式聯合使用。當前無java實現。

(3)支持的服務模型

TSimpleServer – 簡單的單線程服務模型,常用于測試

TThreadPoolServer – 多線程服務模型,使用標準的阻塞式IO。

TNonblockingServer – 多線程服務模型,使用非阻塞式IO(需使用TFramedTransport數據傳輸方式)

4、 Thrift安裝

下載:http://incubator.apache.org/thrift/download/

安裝要求:

Unix/linux 系統,windows+cygwin

C++語言:g++、boost

java 語言:JDK、Apache Ant

其他語言:Python、PHP、Perl, etc…

編譯安裝:./configure –》make –》make install

1、 利用Thrift部署服務

主要流程:編寫服務說明,保存到.thrift文件 –》根據需要, 編譯.thrift文件,生成相應的語言源代碼 –》根據實際需要, 編寫client端和server端代碼。

(1)編寫服務說明,保存到.thrift文件

一般將服務放到一個.thrift文件中,服務的編寫語法與C語言語法基本一致,在.thrift文件中有主要有以下幾個內容:變量聲明、數據聲明(struct)和服務接口聲明(service, 可以繼承其他接口)。

下面分析Thrift的tutorial中帶的例子tutorial.thrift

包含頭文件:

59行:include “shared.thrift”–

指定目標語言:

65行:namespace cpp tutorial–

定義變量:

80行:const i32 INT32CONSTANT = 9853–

定義結構體:

103行:struct Work {

1: i32 num1 = 0,

2: i32 num2,

3: Operation op,

4: optional string comment,

}—

定義服務:

service Calculator extends shared.SharedService {

void ping(),

i32 add(1:i32 num1, 2:i32 num2),

i32 calculate(1:i32 logid, 2:Work w) throws (1:InvalidOperation ouch),

oneway void zip()

}

(2)根據需要, 編譯.thrift文件,生成相應的語言源代碼,以java和C++語言為例

     

要生成C++代碼:./thrift --gen cpp tutorial.thrift,結果代碼存放在gen-cpp目錄下

        要生成java代碼:./thrift --gen java tutorial.thrift,結果代碼存放在gen-java目錄下

       

(3) 根據需要,編寫client端和server端代碼

client端和sever端代碼要調用編譯.thrift生成的中間文件。

下面分析cpp文件下面的CppClient.cpp和CppServer.cpp代碼

在client端,用戶自定義CalculatorClient類型的對象(用戶在.thrift文件中聲明的服務名稱是Calculator, 則生成的中間代碼中的主類為CalculatorClient), 該對象中封裝了各種服務,可以直接調用(如client.ping()), 然后thrift會通過封裝的rpc調用server端同名的函數。

在server端,需要實現在.thrift文件中聲明的服務中的所有功能,以便處理client發過來的請求。


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
91精品国产网站| 国产精品日韩欧美| 欧美中文字幕在线播放| 欧美有码在线视频| 亚洲黄色av女优在线观看| 中文.日本.精品| 久久综合久久美利坚合众国| 91日本视频在线| 欧美丝袜一区二区三区| 国产视频精品在线| 亚洲午夜精品久久久久久久久久久久| 俺去亚洲欧洲欧美日韩| 一区二区三区国产在线观看| 亚洲欧美一区二区三区情侣bbw| 欧美日韩美女在线观看| 精品中文字幕在线2019| 成人av在线网址| 国产精品久久久久久久久久东京| 欧美国产亚洲视频| 欧美成人中文字幕| 久久av资源网站| 国产精品久久久av久久久| 在线色欧美三级视频| 亚洲精品一区二三区不卡| 欧美多人爱爱视频网站| 欧美在线视频导航| 欧美黑人一区二区三区| 国产99久久精品一区二区 夜夜躁日日躁| 九九热99久久久国产盗摄| 日韩精品视频在线免费观看| 中文字幕av一区| 亚洲一区二区三区四区在线播放| 伊人久久久久久久久久久久久| 国产精品成人av性教育| 久久99精品久久久久久琪琪| 国产精品久久久久久亚洲影视| 中文字幕欧美日韩精品| 色综合老司机第九色激情| 国产精品揄拍一区二区| 亚洲天堂男人天堂| 555www成人网| 欧美片一区二区三区| 97超级碰在线看视频免费在线看| 国产成人精品在线| 欧美激情a∨在线视频播放| 26uuu另类亚洲欧美日本老年| 欧美孕妇性xx| 欧美精品激情视频| 97视频在线观看网址| 亚洲美女精品久久| 欧美综合在线观看| 亚洲另类激情图| 欧美高清无遮挡| 日韩亚洲成人av在线| 日本亚洲精品在线观看| 亚洲一区二区三| 中文亚洲视频在线| 亚洲高清久久久久久| 一区二区三区美女xx视频| 日韩欧美极品在线观看| 久久精品一区中文字幕| 成人午夜激情网| 超碰91人人草人人干| 欧美在线观看网址综合| 国产97人人超碰caoprom| 亚洲香蕉在线观看| 日韩精品中文字幕有码专区| 国产欧美一区二区三区在线看| 91美女片黄在线观| 亚洲精品成a人在线观看| 久久好看免费视频| 久久精品小视频| 色婷婷久久av| 亚洲综合社区网| 日韩毛片中文字幕| 国产成人精品免高潮费视频| 亚洲影院在线看| 色综合老司机第九色激情| 国产精品高精视频免费| 中文字幕日韩欧美在线视频| 欧美噜噜久久久xxx| 黄色精品在线看| 久久久久一本一区二区青青蜜月| 亚洲视频欧美视频| 亚洲va欧美va在线观看| 麻豆国产精品va在线观看不卡| 午夜精品美女自拍福到在线| 国产精品三级久久久久久电影| 精品国产一区二区三区久久久| 欧美片一区二区三区| 精品偷拍各种wc美女嘘嘘| 亚洲精品国产suv| 亚洲欧美日韩在线一区| 97久久精品视频| 亚洲成色777777在线观看影院| 一区二区欧美日韩视频| 国产日韩欧美夫妻视频在线观看| 日韩中文字幕视频| 一区二区欧美激情| 国产精品久久91| 日韩欧美中文字幕在线播放| 日韩精品在线免费观看视频| 亚洲男人天堂2024| 亚洲精品美女在线| 国产精品久久久久久久av电影| 亚洲一区第一页| 一区二区三区回区在观看免费视频| 国产一区玩具在线观看| 亚洲黄色成人网| 亚洲国产精品一区二区三区| 亚洲欧美日韩中文视频| 亚洲国产精品视频在线观看| 亚洲国产精品一区二区三区| 国产在线观看精品一区二区三区| 日韩电影大全免费观看2023年上| 久久精品久久久久久国产 免费| 久久伊人91精品综合网站| 日韩av手机在线看| 日韩黄色高清视频| 欧美一级bbbbb性bbbb喷潮片| 亚洲性av在线| 国产精品麻豆va在线播放| 亚洲xxxxx电影| 欧美激情亚洲国产| 538国产精品一区二区免费视频| 欧美专区在线观看| 亚州国产精品久久久| xxx一区二区| 亚洲人成电影网站色| 97精品国产97久久久久久| 久久久久久国产精品久久| 国产成人精品999| 欧美激情在线有限公司| 欧洲亚洲免费在线| 81精品国产乱码久久久久久| 欧美电影在线播放| 欧美xxxx做受欧美.88| 久久精品99久久香蕉国产色戒| 欧美视频在线视频| 疯狂做受xxxx欧美肥白少妇| 成人黄色免费看| 国产视频自拍一区| 日韩欧美中文第一页| 欧美激情在线播放| 国产精品久久久久久中文字| 久久视频免费观看| 国产美女扒开尿口久久久| 国产美女精品视频| 日韩在线免费视频| 91香蕉嫩草影院入口| 国产一区二区三区日韩欧美| 国产精品丝袜一区二区三区| 中文字幕v亚洲ⅴv天堂| 国产原创欧美精品| 精品无码久久久久久国产| 亚洲女人天堂色在线7777| 在线成人一区二区| 成人久久久久爱| 国产成人精品日本亚洲专区61| 尤物99国产成人精品视频| 精品高清一区二区三区| 欧美日韩激情网| 日本电影亚洲天堂| 久久精品人人做人人爽|