亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

在Python中使用gRPC的方法示例

 更新時(shí)間:2018年08月08日 08:32:09   作者:Xin Qiu  
這篇文章主要介紹了在Python中使用gRPC的方法示例,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧

本文介紹了在Python中使用gRPC的方法示例,分享給大家,具體如下:

使用Protocol Buffers的跨平臺(tái)RPC系統(tǒng)。

安裝

使用 pip

pip install grpcio
pip install grpcio-tools googleapis-common-protos

gRPC由兩個(gè)部分構(gòu)成,grpcio 和 gRPC 工具, 后者是編譯 protocol buffer 以及提供生成代碼的插件。

使用

編寫protocol buffer

使用 gRPC 首先需要做的是設(shè)計(jì) protocol buffer。新建一個(gè) msg.proto 文件。

syntax = "proto3";

service MsgService {
 rpc GetMsg (MsgRequest) returns (MsgResponse){}
}

message MsgRequest {
  string name = 1;
}

message MsgResponse {
  string msg = 1;
}

以上面的這個(gè)消息服務(wù)為例,首先是規(guī)定語法,這里使用的是 proto3 的語法。接著使用 service 關(guān)鍵字定義服務(wù),gRPC 提供4種 RPC 類型的服務(wù),這里定義的是第一種單一請(qǐng)求單一回應(yīng),類似普通的函數(shù)調(diào)用,其他的使用到了 stream 關(guān)鍵字,將其放在括號(hào)里,代表這個(gè)數(shù)據(jù)是流數(shù)據(jù)。這個(gè)以后再來研究,本次先設(shè)計(jì)一個(gè)簡單的RPC。

之后定義兩個(gè) message ,一個(gè)是請(qǐng)求的結(jié)構(gòu),一個(gè)是回應(yīng)的結(jié)果。 這里表示這個(gè)數(shù)據(jù)結(jié)構(gòu)是字符串,protocol buffer 還可以定義為 int32,int64,double,float 等等。這里賦予的初值可以隨便填寫,實(shí)際使用中,會(huì)被賦予新的值。

生成接口代碼

因?yàn)橹鞍惭b好了一些輔助插件,使用這里直接可以生成。

python -m grpc_tools.protoc -I . --pythoout=. --grpc_python_out=. msg.proto

這里會(huì)生成兩個(gè)文件, msg_pb2.pymsg_pb2_grpc.py 。這兩個(gè)文件是為后續(xù)的服務(wù)端和客戶端所用。前者是定義了一些變量,例如 _MSGREQUEST 中就包含了請(qǐng)求函數(shù)的名字,可接受的變量,實(shí)際上還是 msg.proto 里定義的東西。

創(chuàng)建服務(wù)端

首先需要導(dǎo)入 RPC 必備的包,以及剛才生成的兩個(gè)文件。

import grpc
import msg_pb2
import msg_pb2_grpc

因?yàn)?RPC 應(yīng)該長時(shí)間運(yùn)行,考慮到性能,還需要用到并發(fā)的庫。

from concurrent import futures
import time

_ONE_DAY_IN_SECONDS = 60 * 60 * 24

在 Server 中,主要是實(shí)現(xiàn)服務(wù),按照 msg.proto 定義的,這里需要寫一個(gè)服務(wù)類 MsgServicer ,這個(gè)類需要實(shí)現(xiàn)之前定義的 GetMsg 。

class MsgServicer(msg_pb2_grpc.MsgServiceServicer):

  def GetMsg(self, request, context):
    print("Received name: %s" % request.name)
    return msg_pb2.MsgResponse(msg='Hello, %s!' % request.name)

GetMsg 接收到的請(qǐng)求是在 request 中, msg.proto 中定義的 name 就是 request.name ,接著在 GetMsg 中設(shè)計(jì) msg.proto 中定義的 MsgResponse 。

之后實(shí)現(xiàn)啟動(dòng)服務(wù)的部分即可。

def serve():
  server = grpc.server(futures.ThreadPoolExecutor(max_workers=10))
  msg_pb2_grpc.add_MsgServiceServicer_to_server(MsgServicer(), server)
  server.add_insecure_port('[::]:50051')
  server.start()
  try:
    while True:
      time.sleep(_ONE_DAY_IN_SECONDS)
  except KeyboardInterrupt:
    server.stop(0)

通過并發(fā)庫,將服務(wù)端放到多進(jìn)程里運(yùn)行。

完整 msg_server.py 代碼如下

import grpc
import msg_pb2
import msg_pb2_grpc

from concurrent import futures
import time

_ONE_DAY_IN_SECONDS = 60 * 60 * 24


class MsgServicer(msg_pb2_grpc.MsgServiceServicer):

  def GetMsg(self, request, context):
    print("Received name: %s" % request.name)
    return msg_pb2.MsgResponse(msg='Hello, %s!' % request.name)


def serve():
  server = grpc.server(futures.ThreadPoolExecutor(max_workers=10))
  msg_pb2_grpc.add_MsgServiceServicer_to_server(MsgServicer(), server)
  server.add_insecure_port('[::]:50051')
  server.start()
  try:
    while True:
      time.sleep(_ONE_DAY_IN_SECONDS)
  except KeyboardInterrupt:
    server.stop(0)

if __name__ == '__main__':
  serve()

創(chuàng)建客戶端

客戶端相對(duì)簡單一些,這里我寫了一個(gè)簡單的客戶端。

import grpc

import msg_pb2
import msg_pb2_grpc

def run():
  # NOTE(gRPC Python Team): .close() is possible on a channel and should be
  # used in circumstances in which the with statement does not fit the needs
  # of the code.
  with grpc.insecure_channel('localhost:50051') as channel:
    stub = msg_pb2_grpc.MsgServiceStub(channel)
    response = stub.GetMsg(msg_pb2.MsgRequest(name='world'))
  print("Client received: " + response.msg)


if __name__ == '__main__':
  run()

使用 grpc.insecure_channel('localhost:50051') 進(jìn)行連接 服務(wù)端, 接著在這個(gè) channel 上創(chuàng)建 stub , 在 msg_pb2_grpc 里可以找到 MsgServiceStub 這個(gè)類相關(guān)信息。這個(gè) stub 可以調(diào)用遠(yuǎn)程的 GetMsg 函數(shù)。 MsgRequest 中的 namemsg.proto 中定義的數(shù)據(jù)。在回應(yīng)里可以得到 msg.proto 中定義的 msg 。

運(yùn)行

首先運(yùn)行 python msg_server.py 啟動(dòng)服務(wù)端,接著運(yùn)行 python msg_client.py 機(jī)會(huì)看到客戶端接收到了服務(wù)端傳來的消息。以上就是一個(gè)簡單的 RPC 的使用。

總結(jié)

這里只是簡單的用了一下 gRPC,關(guān)于另外三種模式,還在摸索。比起gRPC,我感覺簡單 RestFul 更討我喜歡。

以上就是本文的全部內(nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • python里 super類的工作原理詳解

    python里 super類的工作原理詳解

    這篇文章主要介紹了python里 super類的工作原理詳解,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-06-06
  • python 窮舉指定長度的密碼例子

    python 窮舉指定長度的密碼例子

    這篇文章主要介紹了python 窮舉指定長度的密碼例子,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2020-04-04
  • Python2.7+pytesser實(shí)現(xiàn)簡單驗(yàn)證碼的識(shí)別方法

    Python2.7+pytesser實(shí)現(xiàn)簡單驗(yàn)證碼的識(shí)別方法

    這篇文章主要介紹了Python2.7+pytesser實(shí)現(xiàn)簡單驗(yàn)證碼的識(shí)別方法,簡單分析了pytesser的安裝及Python2.7環(huán)境下實(shí)現(xiàn)驗(yàn)證碼識(shí)別的相關(guān)操作技巧,需要的朋友可以參考下
    2017-12-12
  • 基于python3 pyQt5 QtDesignner實(shí)現(xiàn)窗口化猜數(shù)字游戲功能

    基于python3 pyQt5 QtDesignner實(shí)現(xiàn)窗口化猜數(shù)字游戲功能

    這篇文章主要介紹了基于python3 pyQt5 QtDesignner實(shí)現(xiàn)窗口化猜數(shù)字游戲功能,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2019-07-07
  • PyCharm插件開發(fā)實(shí)踐之PyGetterAndSetter詳解

    PyCharm插件開發(fā)實(shí)踐之PyGetterAndSetter詳解

    這篇文章主要介紹了PyCharm插件開發(fā)實(shí)踐-PyGetterAndSetter,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2021-10-10
  • python中使用pyhook實(shí)現(xiàn)鍵盤監(jiān)控的例子

    python中使用pyhook實(shí)現(xiàn)鍵盤監(jiān)控的例子

    這篇文章主要介紹了python中使用pyhook實(shí)現(xiàn)鍵盤監(jiān)控的例子,包含pyhook的下載地址和手冊(cè)地址及一個(gè)Windows下的監(jiān)控實(shí)例,需要的朋友可以參考下
    2014-07-07
  • 淺談Python線程的同步互斥與死鎖

    淺談Python線程的同步互斥與死鎖

    這篇文章主要介紹了淺談Python線程的同步互斥與死鎖,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-03-03
  • Python接口傳輸url與flask數(shù)據(jù)詳解

    Python接口傳輸url與flask數(shù)據(jù)詳解

    這篇文章主要介紹了Python通過接口傳輸url與flask數(shù)據(jù),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2022-09-09
  • Python實(shí)現(xiàn)求解一元二次方程的方法示例

    Python實(shí)現(xiàn)求解一元二次方程的方法示例

    這篇文章主要介紹了Python實(shí)現(xiàn)求解一元二次方程的方法,涉及Python基于math包進(jìn)行數(shù)值運(yùn)算相關(guān)操作技巧,需要的朋友可以參考下
    2018-06-06
  • 詳解Python中的動(dòng)態(tài)屬性和特性

    詳解Python中的動(dòng)態(tài)屬性和特性

    本篇文章主要介紹了詳解Python中的動(dòng)態(tài)屬性和特性,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2018-04-04

最新評(píng)論