thrift介紹及應用(二)—簡單應用

原文:http://blog.csdn.net/guxch/article/details/12162131

-----------------------------------------------------------------------------------

【接上文“thrift介紹及應用(一)—介紹”】


六、一個最簡單的實例

Thrift文件(demo.thirft,來自官網)如下:

[plain]?view plaincopy
  1. struct?UserProfile???
  2. {??
  3. ??1:i32?uid,??
  4. ??2:string?name,??
  5. ??3:string?blurb??
  6. }??
  7. ??
  8. service?UserStorage???
  9. {??
  10. ?void?store(1:?UserProfile?user),??
  11. ?UserProfile?retrieve(1:?i32?uid)??
  12. }??
運行

[plain]?view plaincopy
  1. thrift?–gen?cpp?demo.thrift??
則生成的文件如下:


  • demo_constants:這個文件似乎沒有用,可以在其中定義全局變量之類的東西。
  • demo_types:類型定義(例子中的structUserProfile)都在這個文件中。
  • UserStorage:這個文件比較重要,內容比較多,其中的內如下圖。圖左邊是兩個service方法的傳入傳出參數,注意其中每個的實現都有兩個,一個是帶p的,被用在客戶端代碼中,另一個是不帶p的,被用在服務器端代碼中,其實它們的代碼相當一致(相同的函數部分),不知道thrift這樣做的用意在哪。圖右邊UserStorageIf是消息接口定義,UserStorageIfFactory等是接口的“工廠”。UserStorageNull挺有意思,大概是什么都不做(既然什么都不做,要它做什么呢?)。UserStorageMultiface是將多個UserStorageIf集合起來(vector)處理。對用戶來講,客戶端真正有意義的代碼在UserStorageClient中,寫客戶端時,需要認真查看其接口,在其上編寫自己的業務邏輯。服務器的處理過程在UserStorageProcess類中(但我們自己邏輯在另外的地方)。
  • UserStorage_server.skeleton:這個是服務器端的框架(其實它可以運行),我們自己的邏輯(例子中store到數據庫中或從數據庫中retrieve)在UserStorageHandler類中實現,這個類從UserStorageIf繼承而來。文件中還有一個main函數,其中給出了以TSimpleServer形式(單線程)實現的服務器。實際的應用中,UserStorage_server.skeleton這個文件將被拆分,業務邏輯可能有若干文件,服務器端的實現也許要復雜一些,與其他業務構成一個main函數,這里的main可能叫做thriftserver_main更合適一些。

需要強調的是,thrift有自己的網絡傳輸格式,因此thrift應用適合于我們不關心傳輸過程,只關心我們自己的應用層的消息的傳遞(也就是RPC的概念)的場合,如果規定了網絡傳輸協議,thrift并不適合。

其他實際的應用見hadoop和Hbase的Thrift接口說明。

?

【注:本文參考了Mark Slee, Aditya Agarwal and Marc Kwiatkowski寫的“Thrift:Scalable Cross-Language Services Implementation”一文,該文是Thrift的White Paper。】



本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/539272.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/539272.shtml
英文地址,請注明出處:http://en.pswp.cn/news/539272.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

打游戲的教育意義

夜色已深,一個男孩子還在打游戲。門忽然開了,媽媽走了進來,她把一碗陽春面擺在桌子上。說:"歇息一會兒,趁熱把這碗面吃了吧。"孩子嗯了一聲,眼睛沒有離開屏幕。媽媽生怕打攪孩子,悄悄…

python快速編程入門課本第六章_python編程快速上手第六章實踐項目參考code

代碼如下: 題目的意思是通過一個函數將列表的列表顯示在組織良好的表格中,每列右對齊 tableData [[apples, oranges, cherries, banana], [Alice, Bob, Carol, David], [dogs, cats, moose, goose]]apples Alice dogs oranges Bob cats cherries Carol …

計算機硬件配置組件,配置vcenter server的硬件(默認指windows版本的)

一般來說vcenter的硬件需求與它管理的主機和VM有直接關系1. vcenter server的最低硬件配置Two 64-bit CPUs or a single dual-core 64-bit CPU.2 GHz processor or faster.4 GB of RAM or more.4 GB of free disk space.A network adapter (Gigabit Ethernet strongly recommen…

標準評分卡分數計算原理_評分卡的形式、刻度及應用場景

 看到有伙伴提問:①我們的評分卡做好后,后續的使用策略是什么呀,都有哪些方向? ②評分卡分數切割點如何定,制定的業務邏輯是什么?其實,這個問題不好回答,也好回答。一方…

hexeditor 復制二進制值_MySQL復制全解析 Part 6 MySQL GTID 生命周期

實驗環境此次實驗的環境如下MySQL 5.7.25Redhat 6.10操作系統賬號:mysql數據庫復制賬號:repl復制格式:基于行的復制通過前面的介紹我們知道MySQL的復制有兩種方法基于二進制日志文件位置基于GTID上一節的內容為GTID的格式和存儲,這節根據官方文檔我們說GTID的生命周…

Thrift介紹與應用(三)—hbase的thrift接口

原文:http://blog.csdn.net/guxch/article/details/12163047 ----------------------------------------------------------------------------------- 一、概述 Hbase是目前比較火的列存儲數據庫,由于Hbase是用Java寫的,因此它原生地提供了…

Linux/Unix 新手和專家教程

你正在找一些高質量的Linux 和 UNIX 的教程嗎?如果是,這篇文章會告訴你到哪去找到這些教程。這里我們將給出超過30個相當的不錯的 Linux 和 UNIX 在線的教程。 需要大家注意的是,他們都是英文的,也許有一些也經被翻譯到了中文社區…

自動ip的計算機共享打印,局域網內自動獲取ip地址怎么設置打印機共享文件夾...

在局域網環境中,為了盡可能地節省辦公成本,很多用戶都會選擇在局域網中架設、部署共享打印機,以便在單位的任何角落處都能方便、自如地進行打印操作。下面是學習啦小編為大家整理的關于局域網內自動獲取ip地址怎么設置打印機共享文件夾,一起來看看吧!局域網內自動獲…

高級數據分析1代碼_用Python進行數據分析,讓你一看就會

本書詳細介紹利用Python進行操作、處理、清洗和規整數據等方面的具體細節和基本要點。雖然本書的標題是“數據分析”,重點卻是Python編程、庫,以及用于數據分析的工具。第1章 準備工作第2章 Python語法基礎,IPython和Jupyter Notebooks第3章 …

工期日歷天計算器_天津實地告訴你:房建項目是怎樣保節點,搶工期的?

工程概況天津實地薔薇花園住宅地塊項目共計由24棟單體住宅、2棟配建及地下人防車庫組成,其中12層小高層4棟、13層小高層1棟、19棟7層洋房。總建建筑面積為139348.62㎡,地上99348㎡,地下40000㎡,人防面積為14236㎡。工期目標項目施…

thrift介紹及應用(四)—hadoop的thrift接口

原文:http://blog.csdn.net/guxch/article/details/12163519 ----------------------------------------------------------------------------------- 一、概述 hadoop是目前使用比較多的分布式文件系統,由于hadoop是用Java寫的,對非Java程…

遲到的年度總結,我們應該收放自如

現在已經2018年3月了,這篇2017的年度總結顯得晚了一點,但意義非凡,讓我有了更多的反省和思考,我相信大家讀完一定會有收獲。好了,廢話不多說進入主題。別用學習來逃避成長這話說的簡直是屁話,不是學習才會成…

測試fps游戲反應速度軟件,FPS反應速度提速

靜謐無聲,生死一瞬,說的就是FPS游戲,沒有哪一個種類的游戲可以比擬我們FPS玩家對于反應速度的追求,更快更準哪怕提速只是1毫秒,無數高手之所以為高手就是因為他們可以打出我們看起來不可能完成的擊殺,特別是…

html5中單選框被選中把值傳給后臺_HTML5的表單設計

使用過Delphi的程序員,對Form這個詞應該比較熟悉。在Delphi中,Form被翻譯為“界面、窗口”,作用是:為用戶提供界面,供用戶輸入信息,向用戶展示處理結果。HTML5中也有Form,功能與Delphi中的Form差…

python科赫曲線繪制正方形_Python數據處理從零開始----第四章(可視化)(14)使用seaborn繪制熱圖...

目錄 Python數據處理從零開始----第四章(可視化)①③多變量繪圖 Python數據處理從零開始----第四章(可視化)(14)使用seaborn繪制熱圖 seaborn.heatmapHeat maps顯示數字表格數據,其中單元格根據…

Hive的系統架構

一、架構圖 二、各組件 用戶接口:包括 CLI(控制臺命令),JDBC/ODBC,WebUI。 CLI,即Shell命令行 JDBC/ODBC 是 Hive 的Java,與使用傳統數據庫JDBC的方式類似 WebGUI是通過瀏覽器訪問 Hive --…

8266獲取網絡時間

8266獲取網絡時間 今天第一次用阿里的博客寫點東西感受一下....sntp.sync("ntp1.aliyun.com",function()print("sync succeeded")end,function(index)print("failed : "..index)end)用的SNTP 然后打印時間 time rtctime.epoch2cal(rtctime.get(…

重慶高考計算機分數線,重慶高考歷年分數線

2019年一、普通文理類(一) 文史類本科第一批 545分本科第二批 458分高職專科批 180分(二) 理工類本科第一批 525分本科第二批 435分高職專科批 180分二、藝術類(一)本科批1.美術類 336分2.音樂類(1)音樂學 359分(2)音樂表演(聲樂、鋼琴、器樂) 275分3.編導類 430分4.影視類(1)表…

坐標不顯示_Simpack不顯示坐標軸方向的解決方法

經常有用戶咨詢Simpack軟件打開模型時,不能顯示坐標軸的x、y、z方向,這個問題對建模有很大的影響。本文是蘭州交通大學陳龍同學提供的解決方法,供大家參考。使用Simpack軟件建模時,會遇到這種情況:比如要創建標記點時&…

th:text為null報錯_為vue3.0的學習TS解讀高級類型

知識點摘要本節課主要關鍵詞為: 自動類型推斷 / 類型斷言 / 類型別名(type) / 映射類型(Pick/Record等...) / 條件類型(extends) / 類型推斷(infer)自動類型推斷(不用你標類型了,ts自己猜)大家現在寫ts的時候一定會在每個變量后面都加上類型吧? 但是?現在告訴大家有些情況下你…