gRPC 在 Python中的应用
来源:互联网 发布:用mac输入英文破折号 编辑:程序博客网 时间:2024/06/05 18:51
gRPC 简介:
gRPC 是一款高性能、开源的 RPC 框架,产自 Google,基于 ProtoBuf 序列化协议进行开发,支持多种语言(Golang、Python、Java等),本篇只介绍 Python 的 gRPC 使用。因为 gRPC 对 HTTP/2 协议的支持使其在 Android、IOS 等客户端后端服务的开发领域具有良好的前景。gRPC 提供了一种简单的方法来定义服务,同时客户端可以充分利用 HTTP2 stream 的特性,从而有助于节省带宽、降低 TCP 的连接次数、节省CPU的使用等。
安装:
gRPC 的安装:
$ pip install grpcio
安装 ProtoBuf 相关的 python 依赖库:
$ pip install protobuf
安装 python grpc 的 protobuf 编译工具:
$ pip install grpcio-tools
实践:
下面我们使用 gRPC 定义一个接口,该接口实现对传入的数据进行大写的格式化处理。
* 创建项目 python demo 工程:
- client目录下的 main.py 实现了客户端用于发送数据并打印接收到 server 端处理后的数据
- server 目录下的 main.py 实现了 server 端用于接收客户端发送的数据,并对数据进行大写处理后返回给客户端
- example 包用于编写 proto 文件并生成 data 接口
- 定义 gRPC 接口:
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
编译 protobuf:
$ python -m grpc_tools.protoc -I. –python_out=. –grpc_python_out=. ./data.proto #在 example 目录中执行编译,会生成:data_pb2.py 与 data_pb2_grpc.py
实现 server 端:
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
- 13
- 14
- 15
- 16
- 17
- 18
- 19
- 20
- 21
- 22
- 23
- 24
- 25
- 26
- 27
- 28
- 29
- 实现 client 端:
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
- 13
- 14
- 15
- 16
- 执行验证结果:
- 先启动 server,之后再执行 client
- client 侧控制台如果打印的结果为:“received: HELLO,WORLD!” ,证明 gRPC 接口定义成功
- 先启动 server,之后再执行 client
阅读全文
0 0
- gRPC 在 Python中的应用
- Grpc在Android中的用法
- Grpc 在Android中的配置
- 在python中使用grpc和protobuf
- Grpc在Android中的封装及使用
- JSON在python中的应用
- subprocessing在python中的应用
- python在数据库中的应用
- YAML在python中的应用
- Grpc在Python下的小小小操作
- Python RPC 之 gRPC
- GRPC python编译.proto
- 正则表达式在python中的应用
- python在网购中的小应用
- Python在HTTP接口测试中的应用
- XPath在python中的高级应用
- multiprocessing在python中的高级应用-进程
- Python在HTTP接口测试中的应用
- WIN10 java环境变量配置
- VMWare里CentOS7与win10共享文件
- CF contest 888 problem E 【思维 + 状压 + 中途相遇法(折半搜索)】
- 杭电2017新生赛1007-找方块
- 动态数据结构
- gRPC 在 Python中的应用
- hibernate_day03_09_多对多操作
- C语言——Linux项目:文件复制命令的实现
- 11AIncreasing Sequence
- 随便写点关于我的github仓库
- 6.7 接口参数
- 超大背包问题 (折半枚举)
- uml类图与代码
- BigDecimal、DecimalFormat工具类-浮点类型计算格式化-史上最全=_=