婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > python實現Thrift服務端的方法

python實現Thrift服務端的方法

熱門標簽:蓋州市地圖標注 地圖標注微信發送位置不顯示 315電話機器人廣告 南京銷售外呼系統軟件 房產電銷外呼系統 地圖標注的意義點 地圖制圖標注位置改變是移位嗎 上海機器人外呼系統哪家好 浙江電銷卡外呼系統好用嗎

近期在項目中存在跨編程語言協作的需求,使用到了Thrift。本文將記錄用python實現Thrift服務端的方法。

環境準備

  • 根據自身實際情況下載對應的Thrift編譯器,比如我在Windows系統上使用的是thrift-0.9.3.exe 。下載地址:http://archive.apache.org/dist/thrift/
  • python安裝thrift庫:pip install thrift

編寫.thrift文件

.thrift文件定義了Thrift服務端和Thrift客戶端的通信接口,在該文件中定義的接口需由服務端實現,并可被客戶端調用。Thrift編譯器會調用.thrift文件生成不同語言的thrift代碼,用于之后實現thrift服務端或thrift客戶端。

.thrift文件的編寫規則可參考Thrift白皮書。下面將以demo.thrift文件舉例

service DemoService{
    string ping(1:string param)
    mapi32,string> get_int_string_mapping_result(1:i32 key, 2:string value)
    bool get_bool_result()
}

生成python對應的thrift代碼

使用以下命令可以生成不同語言的thrift代碼:

thrift --gen language> Thrift filename>

 通過thrift-0.9.3.exe --gen py demo.thrift 命令生成python版本的thrift文件,文件夾為gen-py,如下所示:

編寫服務端

編寫服務端server.py,用于實現在demo.thrift文件中定義的接口功能。

from thrift.transport import TSocket
from thrift.transport import TTransport
from thrift.protocol import TBinaryProtocol
from thrift.server import TServer
import sys

sys.path.append("./gen-py/")
from demo import DemoService
import random


class DemoServer:
    def __init__(self):
        self.log = {}

    def ping(self, param):
        return "echo:" + param

    def get_int_string_mapping_result(self, key, value):
        return {key: value}

    def get_bool_result(self):
        return random.choice([True, False])


if __name__ == '__main__':
    # 創建處理器
    handler = DemoServer()
    processor = DemoService.Processor(handler)

    # 監聽端口
    transport = TSocket.TServerSocket(host="0.0.0.0", port=9999)

    # 選擇傳輸層
    tfactory = TTransport.TBufferedTransportFactory()

    # 選擇傳輸協議
    pfactory = TBinaryProtocol.TBinaryProtocolFactory()

    # 創建服務端
    server = TServer.TThreadPoolServer(processor, transport, tfactory, pfactory)

    # 設置連接線程池數量
    server.setNumThreads(5)

    # 啟動服務
    server.serve()

編寫客戶端用于測試

編寫客戶端client.py,用于測試服務端功能是否可用。

from thrift import Thrift
from thrift.transport import TSocket
from thrift.transport import TTransport
from thrift.protocol import TBinaryProtocol
import sys
sys.path.append("./gen-py/")

from demo import DemoService


if __name__ == '__main__':
    transport = TSocket.TSocket('127.0.0.1', 9999)
    transport = TTransport.TBufferedTransport(transport)
    protocol = TBinaryProtocol.TBinaryProtocol(transport)
    client = DemoService.Client(protocol)

    # 連接服務端
    transport.open()

    recv = client.ping("test")
    print(recv)

    recv = client.get_int_string_mapping_result(10, "MyThrift")
    print(recv)

    recv = client.get_bool_result()
    print(recv)

    # 斷連服務端
    transport.close()

編寫完成后,整個項目結構如下圖所示:

測試服務端

運行服務端server.py后,運行客戶端client.py,打印的內容如下:

echo:test
{10: 'MyThrift'}
True

此時客戶端能夠正常調用服務端所提供的接口。(PS:在調試過程中,也許需要修改gen-py文件夾中Thrift編譯器生成的python代碼)

以上就是python實現Thrift服務端的方法的詳細內容,更多關于python實現Thrift服務端的資料請關注腳本之家其它相關文章!

您可能感興趣的文章:
  • python thrift搭建服務端和客戶端測試程序
  • python thrift 實現 單端口多服務的過程
  • python3.7通過thrift操作hbase的示例代碼
  • python使用thrift教程的方法示例
  • python利用thrift服務讀取hbase數據的方法
  • python 如何用urllib與服務端交互(發送和接收數據)
  • Python連接Java Socket服務端的實現方法
  • python 實現客戶端與服務端的通信
  • python網絡編程socket實現服務端、客戶端操作詳解
  • Python Websocket服務端通信的使用示例

標簽:克拉瑪依 日照 金華 赤峰 臨汾 陽泉 貴州 雙鴨山

巨人網絡通訊聲明:本文標題《python實現Thrift服務端的方法》,本文關鍵詞  python,實現,Thrift,服務,端,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《python實現Thrift服務端的方法》相關的同類信息!
  • 本頁收集關于python實現Thrift服務端的方法的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 壤塘县| 苏尼特左旗| 义马市| 福安市| 西昌市| 确山县| 皋兰县| 二连浩特市| 崇左市| 麟游县| 遂溪县| 定远县| 余姚市| 湘阴县| 哈巴河县| 浠水县| 休宁县| 泾阳县| 怀远县| 肃南| 陆丰市| 漯河市| 弋阳县| 三河市| 平邑县| 酒泉市| 枣庄市| 德清县| 宿州市| 鸡东县| 绥芬河市| 星子县| 绥中县| 鄂伦春自治旗| 栖霞市| 孟津县| 府谷县| 舞阳县| 周口市| 新龙县| 平顶山市|