亚洲免费在线-亚洲免费在线播放-亚洲免费在线观看-亚洲免费在线观看视频-亚洲免费在线看-亚洲免费在线视频

thrift一個例子 - xiaoshe的專欄 - 博客頻道 -

系統 2322 0

thrift一個例子 - xiaoshe的專欄 - 博客頻道 - CSDN.NET

thrift一個例子

分類: thrift 3164人閱讀 評論 (2) 收藏 舉報

我用的是c++,所以我舉一個c++的例子,簡單說一下thrift的使用入門。

例子描述是這樣的:我們將學生信息(學號,姓名,性別,年齡)由客戶端發送到服務端。

實現這個例子,我們大致要做以下幾部分事情:

(1)書寫.thrift文件

(2)生成cpp文件

(3)編寫客戶端

(4)編譯cpp文件并執行

?

(1)書寫.thrift文件

學生信息是有結構的,所以我們使用thrift的struct即可,為了達到通信的目的,我們必須使用service。

所以最后書寫成的student.thrift文件內容如下:

struct Student{
?1: i32 sno,
?2: string sname,
?3: bool ssex,
?4: i16 sage,
}
service Serv{
?void put(1: Student s),
}

(2)生成cpp文件

生成cpp文件很簡單,只需要一個thrift命令即可:

/home/xiaoshe/opt/bin/thrift -r --gen cpp student.thrift

--gen 后指定生成的語言,生成的cpp存儲在目錄gen-cpp下

命令執行后,將會在 ./gen-cpp/ 目錄下生成如下文件:

Serv.cpp

Serv .h

Serv _server.skeleton.cpp

student _constants.cpp

student _constants.h

student _types.cpp

student _types.h

注意文件的大小寫:

Serv開頭的文件是由service生成的,這個關鍵字很重要,下面還會見到以它開頭的類。

student是根據student.thrift文件的名生成的。

這些文件可以進行編譯,生成最初的服務端。

?

(3)編寫客戶端

使用 thrift 命令后,我們并沒有得到我們想要的客戶端 client 源代碼,因此客戶端程序要由我們自己編寫實現。然而很幸運,我們可以使用下面的代碼段來編寫我們 client 程序:

?

  1. #include?"Serv.h"??//?替換成你的.h ??
  2. #include?<transport/TSocket.h> ??
  3. #include?<transport/TBufferTransports.h> ??
  4. #include?<protocol/TBinaryProtocol.h> ??
  5. ??
  6. using ? namespace ?apache::thrift;??
  7. using ? namespace ?apache::thrift::protocol;??
  8. using ? namespace ?apache::thrift::transport;??
  9. ??
  10. using ?boost::shared_ptr;??
  11. ??
  12. int ?main( int ?argc,? char ?**argv)?{??
  13. ????boost::shared_ptr<TSocket>?socket( new ?TSocket( "localhost" ,?9090));??
  14. ????boost::shared_ptr<TTransport>?transport( new ?TBufferedTransport(socket));??
  15. ????boost::shared_ptr<TProtocol>?protocol( new ?TBinaryProtocol(transport));??
  16. ??
  17. ????transport->open();??
  18. ??
  19. ???? //?我們的代碼寫在這里 ??
  20. ??
  21. ????transport->close();??
  22. ??
  23. ???? return ?0;??
  24. }??

?

保存成文件client.cpp

(4)編譯cpp文件并執行

編譯服務端:g++ -g -I/home/xiaoshe/opt/include/thrift -L/home/xiaoshe/opt/lib/ -lthrift Serv.cpp student_types.cpp?student_constants.cpp Serv_server.skeleton.cpp -o server

?

編譯客戶端:g++ -g -I/home/xiaoshe/opt/include/thrift -L/home/xiaoshe/opt/lib/ -lthrift -lm -pthread -lz -lrt -lssl Serv.cpp student_types.cpp student_constants.cpp client.cpp -o client

運行服務端:./server

運行客戶端:./client

?

(5)傳輸我們的數據Student信息

到此客戶端已經連上了服務端,但服務端只有這樣的響應(No more data to read),因為二者之間還沒有數據交互。

我們把客戶端當做發送端,修改client.cpp向服務端發送數據。

在“ // 我們的代碼寫在這里”

寫下我們的代碼:

// 先創建一個Student類型的變量,Student是我們在student.thrift中定義過的

?Student s;
?s.sno = 123;
?s.sname = "xiaoshe";
?s.ssex = 1;
?s.sage = 30;

// 再定義一個對象client,又是以"Serv"開頭的類

?ServClient client(protocol);

// 最后調用put函數向服務端傳輸數據, put是student.thrift采用service定義的成員函數。

// 調用put后,服務端也調用相應的put()
?client.put(s);

?

?

服務端負責接收數據,也做相應修改:

在類ServHandler()的put()中:

printf("sno=%d sname=%s ssex=%d sage=%d/n", s.sno, s.sname.c_str(), s.ssex, s.sage);

?

最后編譯,運行服務端,啟動客戶端后,服務端收到消息,顯示結果為:

put
sno=123 sname=xiaoshe ssex=1 sage=30

至此,客戶端已能向服務端發送數據了。

thrift一個例子 - xiaoshe的專欄 - 博客頻道 - CSDN.NET


更多文章、技術交流、商務合作、聯系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯系: 360901061

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對您有幫助就好】

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長會非常 感謝您的哦!??!

發表我的評論
最新評論 總共0條評論
主站蜘蛛池模板: 亚洲一区二区中文字幕 | 欧美五月婷婷 | 亚洲欧美中文字幕 | 99热网| 欧美成人毛片一级在线 | 91视频最新地址 | 成人网在线视频 | 性欧美一级毛片在线播放 | 亚洲视频一二三 | 日韩亚洲欧美在线爱色 | 国产色婷婷 | 国产毛片久久久久久国产毛片 | 久久久久青草大香线综合精品 | 中文字幕第13亚洲另类 | 日本成人不卡视频 | 国产亚洲一欧美一区二区三区 | 国产成人aa在线观看视频 | 久久久美女视频 | 轻轻色在线视频中文字幕 | 国产亚洲精品一品区99热 | 久久精品视频99 | 女女女女女女bbbbbb级毛片 | 深夜男人网站 | 免费观看午夜在线欧差毛片 | 伊人网站在线 | 久久久久久久久久久9精品视频 | 国产成人精品一区二区三在线观看 | 香蕉一级视频 | 高清中文字幕免费观在线 | 美女视频很黄很暴黄是免费的 | 奇米影视7777久久精品 | 久草视屏| 亚洲视频观看 | 成人短视频在线观看 | 亚洲国产精品毛片∧v卡在线 | 亚洲麻豆国产精品 | 久久免费精品一区二区 | 国产精品免费入口视频 | 国产精品视频久久 | 精品一区二区三区中文字幕 | 精品少妇一区二区三区视频 |