日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 >

Thirft框架介绍

發(fā)布時間:2024/4/17 43 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Thirft框架介绍 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

?http://dongxicheng.org/search-engine/thrift-framework-intro/

1、前言

Thrift是一個跨語言的服務(wù)部署框架,最初由Facebook于2007年開發(fā),2008年進(jìn)入Apache開源項目。Thrift通過一個中間語言(IDL, 接口定義語言)來定義RPC的接口和數(shù)據(jù)類型,然后通過一個編譯器生成不同語言的代碼(目前支持C++,Java, Python, PHP, Ruby, Erlang, Perl, Haskell, C#, Cocoa, Smalltalk和OCaml),并由生成的代碼負(fù)責(zé)RPC協(xié)議層和傳輸層的實(shí)現(xiàn)。

本文組織結(jié)構(gòu)如下:1)引言 2)架構(gòu)3)支持的數(shù)據(jù)傳輸格式、數(shù)據(jù)傳輸方式和服務(wù)模型 4)Thrift安裝 5)利用Thift部署服務(wù)

關(guān)于thrift使用方法的介紹,參考我這篇文章:Thrift使用指南

關(guān)于thrift client和server的編寫方法,可參考我這篇文章:使用Thrift RPC編寫程序

2、架構(gòu)

Thrift實(shí)際上是實(shí)現(xiàn)了C/S模式,通過代碼生成工具將接口定義文件生成服務(wù)器端和客戶端代碼(可以為不同語言),從而實(shí)現(xiàn)服務(wù)端和客戶端跨語言的支持。用戶在Thirft描述文件中聲明自己的服務(wù),這些服務(wù)經(jīng)過編譯后會生成相應(yīng)語言的代碼文件,然后用戶實(shí)現(xiàn)服務(wù)(客戶端調(diào)用服務(wù),服務(wù)器端提服務(wù))便可以了。其中protocol(協(xié)議層, 定義數(shù)據(jù)傳輸格式,可以為二進(jìn)制或者XML等)和transport(傳輸層,定義數(shù)據(jù)傳輸方式,可以為TCP/IP傳輸,內(nèi)存共享或者文件共享等)被用作運(yùn)行時庫。上圖的詳細(xì)解釋參考引用【1】。

3、 支持的數(shù)據(jù)傳輸格式、數(shù)據(jù)傳輸方式和服務(wù)模型

(1)支持的傳輸格式

TBinaryProtocol – 二進(jìn)制格式.

TCompactProtocol – 壓縮格式

TJSONProtocol – JSON格式

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

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

(2) 支持的數(shù)據(jù)傳輸方式

TSocket -阻塞式socker

TFramedTransport – 以frame為單位進(jìn)行傳輸,非阻塞式服務(wù)中使用。

TFileTransport – 以文件形式進(jìn)行傳輸。

TMemoryTransport – 將內(nèi)存用于I/O. java實(shí)現(xiàn)時內(nèi)部實(shí)際使用了簡單的ByteArrayOutputStream。

TZlibTransport – 使用zlib進(jìn)行壓縮, 與其他傳輸方式聯(lián)合使用。當(dāng)前無java實(shí)現(xiàn)。

(3)支持的服務(wù)模型

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

TThreadPoolServer – 多線程服務(wù)模型,使用標(biāo)準(zhǔn)的阻塞式IO。

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

4、 Thrift安裝

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

安裝要求:

Unix/linux 系統(tǒng),windows+cygwin

C++語言:g++、boost

java 語言:JDK、Apache Ant

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

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

1、 利用Thrift部署服務(wù)

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

(1).thrift文件編寫

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

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

包含頭文件:

59行:include “shared.thrift”

指定目標(biāo)語言:

65行:namespace cpp tutorial

定義變量:

80行:const i32 INT32CONSTANT = 9853

定義結(jié)構(gòu)體:

103行:struct Work {

1: i32 num1 = 0,

2: i32 num2,

3: Operation op,

4: optional string comment,

}

定義服務(wù):

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()

}

???? 要生成C++代碼:./thrift --gen cpp tutorial.thrift,結(jié)果代碼存放在gen-cpp目錄下 ???? 要生成java代碼:./thrift --gen java tutorial.thrift,結(jié)果代碼存放在gen-java目錄下…..

(2) client端和server端代碼編寫

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

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

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

在server端,需要實(shí)現(xiàn)在.thrift文件中聲明的服務(wù)中的所有功能,以便處理client發(fā)過來的請求。

【參考資料】
1、 http://wiki.apache.org/thrift/
2、 http://jnb.ociweb.com/jnb/jnbJun2009.html
3、 http://blog.rushcj.com/tag/thrift/
4、 http://www.vvcha.cn/c.aspx?id=31984
5、 http://www.thoss.org.cn/mediawiki/index.php/Thrift%E7%9A%84%E9%80%9A%E4%BF%A1%E6%9C%BA%E5%88%B6%E5%8F%8A%E5%85%B6%E5%9C%A8cassandra%E4%B8%AD%E7%9A%84%E5%BA%94%E7%94%A8

原創(chuàng)文章,轉(zhuǎn)載請注明: 轉(zhuǎn)載自董的博客

?

總結(jié)

以上是生活随笔為你收集整理的Thirft框架介绍的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。