一個輕量級的tcp交互,thrift的使用

来源:http://www.cnblogs.com/hyfwin/archive/2017/03/25/6618346.html
-Advertisement-
Play Games

Apache Thrift 是 Facebook 實現的一種高效的、支持多種編程語言的遠程服務調用的框架。 安裝thrift 從官網下載 然後按照./configure,make,make install 方式進行安裝,其他系統可以參照官網http://thrift.apache.org/docs/ ...


Apache Thrift 是 Facebook 實現的一種高效的、支持多種編程語言的遠程服務調用的框架。

  • 安裝thrift 從官網下載 然後按照./configure,make,make install 方式進行安裝,其他系統可以參照官網http://thrift.apache.org/docs/install/
  • 定義thrift文件, 相當於通訊雙方的介面定義,
    bool Boolean, one byte * 
    i8 (byte) Signed 8-bit integer * 
    i16 Signed 16-bit integer *
     i32 Signed 32-bit integer *
     i64 Signed 64-bit integer * 
    double 64-bit floating point value *
     string String * binary Blob (byte array) 
    * map<t1,t2> Map from one type to another 
    * list<t1> Ordered list of one type 
    * set<t1> Set of unique elements of one type

     

    類型參考https://git-wip-us.apache.org/repos/asf?p=thrift.git;a=blob_plain;f=tutorial/tutorial.thrift
  • 用thrift生成關於thrift定義的代碼,對應各種語言,我這主要是python,也可以其他的c++,java,命令是thrift --gen <language> <Thrift filename>
  • server和client的編寫,server要多考慮無阻塞,多進程,保證服務正常,調用thrift生成的類,對應定義好的數據類型。
    def init_handler():
        """ sub-process init handler """
        signal.signal(signal.SIGINT, signal.SIG_DFL)
        signal.signal(signal.SIGTERM, signal.SIG_DFL)
        signal.signal(signal.SIGHUP, signal.SIG_DFL)
        signal.signal(signal.SIGUSR1, debug)
    
    def main():
        """ The main entrance """
        port = sys.argv[1]
        signal.signal(signal.SIGINT, exit_signal_handler)
        signal.signal(signal.SIGTERM, exit_signal_handler)
        signal.signal(signal.SIGHUP, exit_signal_handler)
        signal.signal(signal.SIGUSR1, debug)
    
        gc.set_threshold(20000, 10, 10)
        handler = MaitreyaHandler()
        processor = Maitreya.Processor(handler)
        transport = TSocket.TServerSocket(port=port)
        tfactory = TTransport.TBufferedTransportFactory()
        pfactory = TBinaryProtocol.TBinaryProtocolFactory()
    
        # server = TProcessPoolServer(processor, transport, tfactory, pfactory)
        server = TGeventServer.TGeventProcessPoolServer(processor, transport, tfactory, pfactory)
        server.setNumWorkers(WORKER_NUM)
    
        server.setPostForkCallback(init_handler)
    
        print "server started..."
        server.serve()

     


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • svn 鎖的處理: 問題: 1:當用戶在work copy1 中把某個文件或者文件夾鎖住後,刪除了這個工作區,重新取下來work copy2,再操作該文件的時候就報錯說,該文件已經被鎖住,必須先解鎖,但是之前的工作區已經被刪除,無法解鎖; 2:當某用戶 鎖了一個文件或文件夾後,離職了,機器上交了,後... ...
  • 編程時經常需要檢查一系列條件,並據此決定採取什麼措施。在Python中,if語句讓我們能夠檢查程式的當前狀態,並據此採取相應的措施。 5.1 一個簡單的示例 下麵是一個簡短的示例,演示瞭如何使用if語句來正確地處理特殊情形。假設我們有一個汽車列表,並想將其中每輛汽車的名稱列印出來。對於大多數汽車,都 ...
  • [1]概述 [2]配置 [3]基本語法 [4]變數 [5]變數調節器 [6]內置函數 ...
  • 今天想測試java的System的類,沒想到居然出錯了。在同一個包下的java文件System全錯,而其他包中的System沒錯。上網查了下資料,原來我是重定義了System類,覆蓋了原來的System類導致原System類中的屬性和方法不能使用。 從圖中可以看到我定義的公有類是System,覆蓋原 ...
  • 字元串 在java中,字元串被作為String類型的對象處理。String類位於java.lang包中,預設情況下,該包被自動導入所有的程式。 創建String對象的方法: String對象創建後不能被修改,是不可變的,所謂的修改其實是創建了新的對象,所指向的記憶體空間不同。 如果需要一個可以改變的字 ...
  • 一、準備所需的jar包 1.1所需jar包 1.Spring框架jar包 2.Mybatis框架jar包 3.Spring的AOP事務jar包 4.Mybatis整合Spring中間件jar包 5.aspectj框架jar包 6.aop聯盟jar包 7.資料庫驅動jar包 8.數據源c3p0所需ja ...
  • 額,,,, 前幾天,剛開始玩力熱實驗, 卻沒想到,平時愛玩的實驗誤差分析的不確定度竟然計算那麼複雜,連夜寫了一段代碼, (大佬勿噴,物理專業的小白剛自學,應該也沒人看。。。) 為了以後我用著方便,都寫成了函數塊,接下來會隨著實驗作業和Java的學習,繼續完善 (現在,不明白的是,兩組數,在定義的函數 ...
  • 此文章是基於 EasyUI+Knockout實現經典表單的查看、編輯 一. 準備工作 1. 點擊此下載相關文件,並把文件放到 ims 工程對應的文件夾下 二. 相關文件介紹 1. user.jsp:用戶管理界面 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...