欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

python實現(xiàn)Thrift服務(wù)端的方法

 更新時間:2021年04月19日 17:02:21   作者:酌三巡  
這篇文章主要介紹了python實現(xiàn)Thrift服務(wù)端的方法,幫助大家更好的理解和學(xué)習(xí)使用python,感興趣的朋友可以了解下

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

環(huán)境準(zhǔn)備

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

編寫.thrift文件

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

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

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

生成python對應(yīng)的thrift代碼

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

thrift --gen <language> <Thrift filename>

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

編寫服務(wù)端

編寫服務(wù)端server.py,用于實現(xiàn)在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__':
    # 創(chuàng)建處理器
    handler = DemoServer()
    processor = DemoService.Processor(handler)

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

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

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

    # 創(chuàng)建服務(wù)端
    server = TServer.TThreadPoolServer(processor, transport, tfactory, pfactory)

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

    # 啟動服務(wù)
    server.serve()

編寫客戶端用于測試

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

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)

    # 連接服務(wù)端
    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)

    # 斷連服務(wù)端
    transport.close()

編寫完成后,整個項目結(jié)構(gòu)如下圖所示:

測試服務(wù)端

運行服務(wù)端server.py后,運行客戶端client.py,打印的內(nèi)容如下:

echo:test
{10: 'MyThrift'}
True

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

以上就是python實現(xiàn)Thrift服務(wù)端的方法的詳細(xì)內(nèi)容,更多關(guān)于python實現(xiàn)Thrift服務(wù)端的資料請關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • python opencv根據(jù)顏色進(jìn)行目標(biāo)檢測的方法示例

    python opencv根據(jù)顏色進(jìn)行目標(biāo)檢測的方法示例

    這篇文章主要介紹了python opencv根據(jù)顏色進(jìn)行目標(biāo)檢測的方法示例,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-01-01
  • Python深入學(xué)習(xí)之對象的屬性

    Python深入學(xué)習(xí)之對象的屬性

    這篇文章主要介紹了Python深入學(xué)習(xí)之對象的屬性,本文從較深的層次講解對象屬性的內(nèi)部運行方式,需要的朋友可以參考下
    2014-08-08
  • Python正則表達(dá)式教程之三:貪婪/非貪婪特性

    Python正則表達(dá)式教程之三:貪婪/非貪婪特性

    這篇文章主要介紹了Python正則表達(dá)式中貪婪/非貪婪特性的相關(guān)資料,文中通過示例代碼介紹的很詳細(xì),對大家具有一定的參考價值,需要的朋友下面來一起看看吧。
    2017-03-03
  • Python 如何實現(xiàn)文件自動去重

    Python 如何實現(xiàn)文件自動去重

    這篇文章主要介紹了Python 實現(xiàn)文件自動去重操作,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-06-06
  • 對Python3.x版本print函數(shù)左右對齊詳解

    對Python3.x版本print函數(shù)左右對齊詳解

    今天小編就為大家分享一篇對Python3.x版本print函數(shù)左右對齊詳解,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-12-12
  • 如何使用Python實現(xiàn)名片管理系統(tǒng)

    如何使用Python實現(xiàn)名片管理系統(tǒng)

    這篇文章主要介紹了如何使用Python實現(xiàn)名片管理系統(tǒng),文章圍繞主題展開詳細(xì)的內(nèi)容介紹,具有一定的參考價值,需要的小伙伴可以參考一下,希望對你的學(xué)習(xí)又是幫助
    2022-08-08
  • Python使用sklearn庫實現(xiàn)的各種分類算法簡單應(yīng)用小結(jié)

    Python使用sklearn庫實現(xiàn)的各種分類算法簡單應(yīng)用小結(jié)

    這篇文章主要介紹了Python使用sklearn庫實現(xiàn)的各種分類算法,結(jié)合實例形式分析了Python使用sklearn庫實現(xiàn)的KNN、SVM、LR、決策樹、隨機(jī)森林等算法實現(xiàn)技巧,需要的朋友可以參考下
    2019-07-07
  • Python中應(yīng)用protobuf的示例詳解

    Python中應(yīng)用protobuf的示例詳解

    這篇文章主要來和大家聊一聊?protobuf,它是一個數(shù)據(jù)序列化和反序列化協(xié)議,因此它和?json?的定位是一樣的。文中的示例代碼講解詳細(xì),感興趣的可以了解一下
    2023-02-02
  • Python數(shù)據(jù)分析numpy的Nan和Inf使用注意點詳解

    Python數(shù)據(jù)分析numpy的Nan和Inf使用注意點詳解

    這篇文章主要為大家介紹了Python數(shù)據(jù)分析numpy的Nan和Inf使用注意點,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-08-08
  • django正續(xù)或者倒序查庫實例

    django正續(xù)或者倒序查庫實例

    這篇文章主要介紹了django正續(xù)或者倒序查庫實例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-05-05

最新評論