广告
返回顶部
首页 > 资讯 > 后端开发 > Python >怎么用Python编写简单的gRPC服务
  • 730
分享到

怎么用Python编写简单的gRPC服务

2023-06-20 13:06:43 730人浏览 安东尼

Python 官方文档:入门教程 => 点击学习

摘要

这篇文章主要介绍了怎么用python编写简单的grpc服务,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。grpc 是可以在任何环境中运行的现代开源高性能 RPC 框架。它可以

这篇文章主要介绍了怎么用python编写简单的grpc服务,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。

grpc 是可以在任何环境中运行的现代开源高性能 RPC 框架。它可以通过可插拔的支持来有效地连接数据中心内和跨数据中心的服务,以实现负载平衡,跟踪,运行状况检查和身份验证。它也适用于分布式计算的最后一英里,以将设备,移动应用程序和浏览器连接到后端服务。

Python编写简单的gRPC服务

grpc官网python参考:https://www.grpc.io/docs/languages/python/quickstart/
Http://grpc.GitHub.io/grpc/python/grpc.html

  • Python 3.5 or higher

  • pip version 9.0.1 or higher

安装gRPC相关的库
grpcio-tools主要用根据我们的protocol buffer定义来生成Python代码,官方解释是Protobuf code generator for gRPC。

#apt install python3-pippip install grpciopip install protobufpip install grpcio_tools

编写proto文件

proto是一个协议文件,客户端和服务器的通信接口正是通过proto文件协定的,可以根据不同语言生成对应语言的代码文件。

heartbeat.proto文件:

syntax = "proto3";message HeartbeatRequest{string Host      = 1;int32  Mem       = 2;int32  Disk      = 3;int32  Cpu       = 4;int64  Timestamp = 5;int64  Seq       = 6;}message HeartbeatResponse{int32  ErrCode   = 1;string ErrMsg    = 2;}

heartbeat_service.proto

syntax = "proto3";import "heartbeat.proto";// HeartBeatServiceservice HeartBeatService{    rpc HeartBeat(HeartbeatRequest) returns(HeartbeatResponse){}}

核心 就是一个 用于生成需要用到数据类型的文件;一个就是用于生成相关调用方法的类。 一个定义数据类型,一个用于定义方法。

通过proto生成.py文件

proto文件需要通过protoc生成对应的.py文件。protoc的下载地址 。下载解压之后,将解压目录添加到path的环境变量中。

pip install grpcioinstall grpcio-tools#pip  install --upgrade protobuf

注意:【下面命令是在proto文件所在的目录执行的,-I 用来指定proto的目录是 . 】

python -m grpc_tools.protoc -I=. --python_out=.. heartbeat.protopython -m grpc_tools.protoc -I=. --grpc_python_out=.. heartbeat_service.proto
  • -I 指定proto所在目录

  • -m 指定通过protoc生成py文件

  • –python_out生成py文件的输出路径

  • heartbeat.proto、heartbeat_service.proto为 输入的proto文件

  • 生成的文件名中 xxx_pb2.py 就是我们刚才创建数据结构文件,里面有定义函数参数和返回数据结构; xxx_pb2_grpc.py 就是我们定义的函数,定义了我们客服端rpc将来要调用方法。

编译客户端和服务端代码

服务端

#!/usr/bin/env python# coding=utf-8import sysfrom concurrent import futuresimport timeimport grpcfrom Google.protobuf.JSON_fORMat import MessageTojsonimport heartbeat_service_pb2_grpcimport heartbeat_pb2from lib.core.log import LOGGERclass HeartBeatSrv(heartbeat_service_pb2_grpc.HeartBeatServiceServicer):    def HeartBeat(self, msg, context):        try:            # LOGGER.info(MessageToJson(msg, preserving_proto_field_name=True))            body = MessageToJson(msg, preserving_proto_field_name=True)            LOGGER.info("Get Heartbeat Request: %s", body)            response = heartbeat_pb2.HeartbeatResponse()            response.ErrCode = 0000            response.ErrMsg = "success"            return response        except Exception as e:            print("exception in heartbeat")            LOGGER.error("RPC Service exception: %s", e)            response = heartbeat_pb2.HeartbeatResponse()            response.ErrCode = 500            response.ErrMsg = "rpc error: %s" % e            return responsedef server(host, rpc_port):    # 这里通过thread pool来并发处理server的任务    # 定义服务器并设置最大连接数,concurrent.futures是一个并发库,类似于线程池的概念    grpc_server = grpc.server(futures.ThreadPoolExecutor(max_workers=100))    # 不使用SSL    grpc_server.add_insecure_port('[::]' + ':' + str(rpc_port))    # This method is only safe to call before the server is started.    #  绑定处理器HeartBeatSrv(自己实现了处理函数)    heartbeat_service_pb2_grpc.add_HeartBeatServiceServicer_to_server(HeartBeatSrv(), grpc_server)    # 该方法只能调用一次, start() 不会阻塞    # 启动服务器    grpc_server.start()    LOGGER.info("server start...")    while 1:        time.sleep(10)    #grpc_server.wait_for_termination()def main():    try:        LOGGER.info("begin start server")        rpc_port = 8090        host = "::"        server(host, rpc_port)    except Exception as e:        LOGGER.error("server start error: %s", e)        time.sleep(5)if __name__ == '__main__':    LOGGER.info(sys.path)    main()

客户端

from time import sleepimport grpcimport heartbeat_pb2import heartbeat_service_pb2_grpcfrom lib.core.log import LOGGERdef run(seq):    option = [('grpc.keepalive_timeout_ms', 10000)]    #    with grpc.insecure_channel(target='127.0.0.1:8090', options=option) as channel:        # 客户端实例        stub = heartbeat_service_pb2_grpc.HeartBeatServiceStub(channel)        # stub调用服务端方法        response = stub.HeartBeat(heartbeat_pb2.HeartbeatRequest(Host='hello grpc', Seq=seq), timeout=10)        LOGGER.info("response ErrCode:%s", response.ErrCode)if __name__ == '__main__':    for i in range(1, 10000):        LOGGER.info("i: %s", i)        sleep(3)        run(i)

感谢你能够认真阅读完这篇文章,希望小编分享的“怎么用Python编写简单的gRPC服务”这篇文章对大家有帮助,同时也希望大家多多支持编程网,关注编程网Python频道,更多相关知识等着你来学习!

--结束END--

本文标题: 怎么用Python编写简单的gRPC服务

本文链接: https://www.lsjlt.com/news/297073.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • 怎么用Python编写简单的gRPC服务
    这篇文章主要介绍了怎么用Python编写简单的gRPC服务,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。gRPC 是可以在任何环境中运行的现代开源高性能 RPC 框架。它可以...
    99+
    2023-06-20
  • 用Python编写简单的gRPC服务的详细过程
    gRPC 是可以在任何环境中运行的现代开源高性能 RPC 框架。它可以通过可插拔的支持来有效地连接数据中心内和跨数据中心的服务,以实现负载平衡,跟踪,运行状况检查和身份验证。它也适用于分布式计算的最后一英里,以将设备...
    99+
    2022-06-02
    Python gRPC服务
  • 怎么用Python编写一个简单的游戏
    本篇内容介绍了“怎么用Python编写一个简单的游戏”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!在这个系列中,我们要用不同的编程语言编写相...
    99+
    2023-06-15
  • 基于Python编写一个简单的http服务器
    目录什么是http分析http请求报文和响应报文格式手写一个简单的http服务器总结本篇文章的python版本为: 什么是http http是一个应用层协议,准确的来说是基于TCP...
    99+
    2023-05-17
    Python实现http服务器 Python http服务器 Python 服务器
  • 基于C++怎么编写一个简单的服务器
    这篇文章主要讲解了“基于C++怎么编写一个简单的服务器”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“基于C++怎么编写一个简单的服务器”吧!先写个简易的controller基类继承反射基类,...
    99+
    2023-07-05
  • 用Python编写一个简单的Http S
    原文地址:Write a simple HTTP server in Python http://www.acmesystems.it/python_httpd 例子中源码: https://github.com/tanzi...
    99+
    2023-01-31
    简单 Python Http
  • 用Python编写简单的微博爬虫
    先说点题外话,我一开始想使用Sina Weibo API来获取微博内容,但后来发现新浪微博的API限制实在太多,大家感受一下: 只能获取当前授权的用户(就是自己),而且只能返回最新的5条,WTF! 所以...
    99+
    2022-06-04
    爬虫 简单 Python
  • HTML怎么编写一个简单的表单
    这篇文章主要介绍了HTML怎么编写一个简单的表单,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。我们先来看下常用的表单元素有哪些: 文本域 文本域通过 &l...
    99+
    2023-06-27
  • 怎么使用Python搭建gRPC服务
    这篇文章主要介绍了怎么使用Python搭建gRPC服务,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。一、概述一个gRPC服务的大体结构图为:图一表明,grpc的服务是跨语言的...
    99+
    2023-06-20
  • 基于Python编写一个简单的服务注册发现服务器
    目录案例展示案例测试如何来写一个注册发现服务器服务器发现核心是啥报文如何定义如何从tcp流中获取记录编写注册发现服务器如何从tcp流中读取数据数据包如何区分类型服务注册服务销毁服务查...
    99+
    2023-05-16
    Python编写服务注册发现服务器 Python服务注册发现服务器 Python 服务器
  • 怎么使用Python写一个简单的JSONParser
    JSON TokenizerJSON 的词法分析,我主要是参考上面这个截图里面的方式,自己写了一个简单的示例。写得比较简单,应该说它只能支持 JSON 的一个简单子集。这里 TOKEN 的种类,参考了 https://json.org,不过...
    99+
    2023-05-14
    Python
  • 怎么用JavaScript编写简单的抽奖程序
    本篇内容介绍了“怎么用JavaScript编写简单的抽奖程序”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!...
    99+
    2022-10-19
  • linux怎么用at命令编写简单的计划任务
    本篇内容介绍了“linux怎么用at命令编写简单的计划任务”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!如果想在linux下计划在将来的某个...
    99+
    2023-06-13
  • python简单程序的编写方法是什么
    这篇文章主要介绍“python简单程序的编写方法是什么”,在日常操作中,相信很多人在python简单程序的编写方法是什么问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”python简单程序的编写方法是什么”的疑...
    99+
    2023-06-17
  • 基于C++编写一个简单的服务器
    本文使用上一期写的反射类,另外我发现<WinSock2.h>这个头文件里有RegisterClass 这个结构,还有typedef RegisterClass Regis...
    99+
    2023-03-14
    C++编写简易服务器 C++编写服务器 C++服务器
  • Java简单的SOAP客户端怎么编写
    编写Java简单的SOAP客户端可以通过以下步骤进行:1. 导入必要的类和包。首先,需要导入`javax.xml.soap`包和相关...
    99+
    2023-09-27
    Java
  • 怎么使用Python编写一个简单的垃圾邮件分类器
    这篇文章主要介绍“怎么使用Python编写一个简单的垃圾邮件分类器”,在日常操作中,相信很多人在怎么使用Python编写一个简单的垃圾邮件分类器问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”怎么使用Pytho...
    99+
    2023-07-06
  • 利用Python编写一个简单的缓存系统
    目录项目展示不用落地的缓存系统系统应该如何实现铺垫python字典基本操作定义一个不用落地的缓存系统数据如何落地将对象保存到磁盘将对象从磁盘中导入到内存中将数据落地和缓存系统结合起来...
    99+
    2023-05-16
    Python实现缓存系统 Python缓存系统 Python缓存
  • 如何用Java编写你自己的简单HTTP服务器
    如何用Java编写你自己的简单HTTP服务器,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。HTTP是个大协议,完整功能的HTTP服务器必须响应资源请求,将URL转换为本地系...
    99+
    2023-06-17
  • python最简单的冒泡排序怎么写
    冒泡排序是一种简单的排序算法,它重复地遍历要排序的列表,比较每对相邻的元素,并按照顺序交换它们,直到整个列表排序完成。下面是Pyth...
    99+
    2023-08-08
    python
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作