跟我學Thrift 1:初識Thrift

為什么有Thrift

學習任何一門新技術之前亏镰,首先要理解扯旷,它產(chǎn)生的背景。Thrift它是RPC一種實現(xiàn)方案索抓,它本質上解決了兩個問題:

1.高效的遠程調用

2.多語言的支持

我們日常生活中钧忽,REST用的很普遍,也能解決這些問題逼肯,那為什么還需要有thrift這樣的RPC技術呢耸黑?

RPC和REST的本質區(qū)別在于,REST它基于HTTP協(xié)議是應用層協(xié)議篮幢,簡單大刊,防火墻友好(80和443端口一般不會背禁用)。但代價是傳輸成本高(HTTP是基于TCP的三椿,必然需要多一層封裝缺菌、拆包的過程)。

RPC基于但是傳輸層協(xié)議搜锰,傳輸效率高男翰,但容易被防火墻阻擋。

所以對于高并發(fā)對互聯(lián)網(wǎng)公司來說纽乱,REST太慢了蛾绎,RPC才是更好對選擇,而Thrift是Twitter的實現(xiàn)鸦列。

基于以上考慮租冠,一般在對外暴露服務時采用REST(防火墻友好),內部通信一般用RPC薯嗤。

Thrift特性

1.獨立于語言的IDL(后面會詳細介紹)

2.它支持世面上的大部分后端編程語言Java(1.7和1.8)顽爹、C++,C#骆姐,js镜粤,node.js,go等14種語言

3.支持namespace(甚至每種語言有自己的namespace)玻褪,用于隔離肉渴,這樣不同namespace下的identifier可以重名

4.支持基本類型、支持常量和枚舉带射、支持containers(list同规,set,map)

5.支持struct和service(service支持繼承)、異常

6.支持異步調用

??它不支持struct繼承(用組合)券勺、方法重載绪钥、多肽。方法不能返回null

Thrift IDL

一個Thrift文件成為一個document关炼,它包含header程腹、Definition

Header:Include,CPPInclude儒拂,NameSpace

Definition:Const|TypeDef |Enum|Struct|Union|Service|BaseType

Thrift網(wǎng)絡通信架構設計

---Server層:用于創(chuàng)建Processor跪楞、輸入輸出Protocol,Transport

---Processor層:用于處理輸入侣灶、輸出流

---Protocol層:read/write data interface

---Transport層:tcp甸祭,http

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市褥影,隨后出現(xiàn)的幾起案子池户,更是在濱河造成了極大的恐慌,老刑警劉巖凡怎,帶你破解...
    沈念sama閱讀 217,185評論 6 503
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件校焦,死亡現(xiàn)場離奇詭異,居然都是意外死亡统倒,警方通過查閱死者的電腦和手機寨典,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,652評論 3 393
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來房匆,“玉大人耸成,你說我怎么就攤上這事≡『瑁” “怎么了井氢?”我有些...
    開封第一講書人閱讀 163,524評論 0 353
  • 文/不壞的土叔 我叫張陵,是天一觀的道長岳链。 經(jīng)常有香客問我花竞,道長,這世上最難降的妖魔是什么掸哑? 我笑而不...
    開封第一講書人閱讀 58,339評論 1 293
  • 正文 為了忘掉前任约急,我火速辦了婚禮,結果婚禮上苗分,老公的妹妹穿的比我還像新娘厌蔽。我一直安慰自己,他們只是感情好俭嘁,可當我...
    茶點故事閱讀 67,387評論 6 391
  • 文/花漫 我一把揭開白布躺枕。 她就那樣靜靜地躺著服猪,像睡著了一般供填。 火紅的嫁衣襯著肌膚如雪拐云。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,287評論 1 301
  • 那天近她,我揣著相機與錄音叉瘩,去河邊找鬼。 笑死粘捎,一個胖子當著我的面吹牛薇缅,可吹牛的內容都是我干的。 我是一名探鬼主播攒磨,決...
    沈念sama閱讀 40,130評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼泳桦,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了娩缰?” 一聲冷哼從身側響起灸撰,我...
    開封第一講書人閱讀 38,985評論 0 275
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎拼坎,沒想到半個月后浮毯,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,420評論 1 313
  • 正文 獨居荒郊野嶺守林人離奇死亡泰鸡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 37,617評論 3 334
  • 正文 我和宋清朗相戀三年债蓝,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片盛龄。...
    茶點故事閱讀 39,779評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡饰迹,死狀恐怖,靈堂內的尸體忽然破棺而出余舶,到底是詐尸還是另有隱情蹦锋,我是刑警寧澤,帶...
    沈念sama閱讀 35,477評論 5 345
  • 正文 年R本政府宣布欧芽,位于F島的核電站莉掂,受9級特大地震影響,放射性物質發(fā)生泄漏千扔。R本人自食惡果不足惜憎妙,卻給世界環(huán)境...
    茶點故事閱讀 41,088評論 3 328
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望曲楚。 院中可真熱鬧厘唾,春花似錦、人聲如沸龙誊。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,716評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至鹤树,卻和暖如春铣焊,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背罕伯。 一陣腳步聲響...
    開封第一講書人閱讀 32,857評論 1 269
  • 我被黑心中介騙來泰國打工曲伊, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人追他。 一個月前我還...
    沈念sama閱讀 47,876評論 2 370
  • 正文 我出身青樓坟募,卻偏偏與公主長得像,于是被迫代替她去往敵國和親邑狸。 傳聞我的和親對象是個殘疾皇子懈糯,可洞房花燭夜當晚...
    茶點故事閱讀 44,700評論 2 354

推薦閱讀更多精彩內容

  • 1. RPC 1.1 簡介 RPC 的主要功能目標是讓構建分布式計算(應用)更容易,在提供強大的遠程調用能力時不損...
    wy_sure閱讀 6,990評論 0 1
  • Thrift是什么单雾? Thrift是Facebook于2007年開發(fā)的跨語言的rpc服框架昂利,提供多語言的編譯功能,...
    jiangmo閱讀 9,415評論 0 6
  • 本文將從大的框架層面來聊聊RPC原理和實現(xiàn)铁坎,既然叫跨語言RPC蜂奸,也將以thrift為例講講跨語言RPC如何實現(xiàn)。在...
    彥幀閱讀 14,545評論 0 19
  • Thrift簡介 The Apache Thrift software framework, for scalab...
    小波同學閱讀 2,764評論 0 7
  • 文/失眠的貓 今天去和姐姐見面硬萍。 我們在同一個城市上學扩所。 每次和姐姐在路口分開的時候都會想哭。 因為姐姐是像家人一...
    失眠的貓cccat閱讀 155評論 0 3