IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 网络协议 -> RPC & gRPC python -> 正文阅读

[网络协议]RPC & gRPC python

RPC

  1. RPC(Remote Procedure Call,远程过程调用)是一种通过网络从远程计算机程序上请求服务,而不需要了解底层网络细节的应用程序通信协议

  2. RPC协议构建于TCP或UDP,或者是HTTP上,允许开发者直接调用另一台服务器上的程序,而开发者无需另外的为这个调用过程编写网络通信相关代码,使得开发网络分布式程序在内的应用程序更加容易。

  3. RPC采用客户端-服务器端的工作模式,请求程序就是一个客户端,而服务提供程序就是一个服务器端。

  4. 当执行一个远程过程调用时,客户端程序首先先发送一个带有参数的调用信息到服务端,然后等待服务端响应。在服务端,服务进程保持睡眠状态直到客户端的调用信息到达。当一个调用信息到达时,服务端获得进程参数,计算出结果,并向客户端发送应答信息。然后等待下一个调用。

gRPC

  1. gRPC 是 Google 开源的基于 Protobuf 和 Http2.0 协议的通信框架,默认采用Protocol Buffers数据序列化协议Protocol Buffers基本语法,支持多种开发语言。

  2. gRPC提供了一种简单的方法来精确的定义服务,并且为客户端和服务端自动生成可靠的功能库

gRPC vs Restful API

  1. gRPC和restful API都提供了一套通信机制,用于server/client模型通信,而且它们都使用http作为底层的传输协议(严格地说, gRPC使用的http2.0,而restful api则不一定。

  2. gRPC可以通过protobuf来定义接口,从而可以有更加严格的接口约束条件。通过protobuf可以将数据序列化为二进制编码,这会大幅减少需要传输的数据量,从而大幅提高性能。

  3. gRPC可以方便地支持流式通信(理论上通过http2.0就可以使用streaming模式, 但是通常web服务的restful api似乎很少这么用,通常的流式数据应用如视频流,一般都会使用专门的协议如HLS,RTMP等,这些就不是我们通常web服务了,而是有专门的服务器应用。

Protobuf

  1. Protobuf是一套类似Json或者XML的数据传输格式和规范,用于不同应用或进程之间进行通信时使用。
  2. 通信时所传递的信息是通过Protobuf定义的message数据结构进行打包,然后编译成二进制的码流再进行传输或者存储。
  3. protobuf经历了protobuf2和protobuf3,目前主流是protobuf3。
    在这里插入图片描述

python操作

pip install grpcio
pip install grpcio-tools

protobuf3

在这里插入图片描述
以proto结尾:

syntax = "proto3";

// 只能发message类的信息
message HelloRequest{
  string name = 1; // name的编号是1
}

生成python文件

python -m grpc_tools.protoc --python_out=. --grpc_python_out=. -I. hello.proto
# 生成两个python文件
# 1. python包
# 2. grpc调用
# -I input -I. 表示是当前目录下找input
# hello.proto 表示proto文件

使用

from proto import hello_pb2

# 转为二进制
request = hello_pb2.HelloRequest()
request.name = "bobby"
res = request.SerializeToString()
print(res)

# 从二进制转回来
request2 = hello_pb2.HelloRequest()
request2.ParseFromString(res)
print(request2.name)

grpc使用

hello.proto

syntax = "proto3";

# 定义grpc服务
service Greeter{
# 参数只可以是message声明的变量
  rpc SayHello(HelloRequest) returns(HelloResponse);
}

message HelloRequest{
# name 的标号为1;
  string name = 1;
}
message HelloResponse{
# 不同message 的标号不冲突;
  string name = 1;
}

server.py

from grpc_hello import hello_pb2, hello_pb2_grpc
from concurrent.futures import ThreadPoolExecutor
import grpc

# 实现服务
# 生产的pb2.grpc文件中已经含有一个Servicer的类
class Greeter(hello_pb2_grpc.GreeterServicer):
# 实现proto定义的方法
    def SayHello(self, request, context):
        return hello_pb2.HelloResponse(name=f"我是{request.name}")


if __name__ == '__main__':
	# 启动一个多线程服务
    server = grpc.server(ThreadPoolExecutor(max_workers=10))
    
    # 将Greeter注册到server中
    hello_pb2_grpc.add_GreeterServicer_to_server(Greeter(), server)

    # 启动
    server.add_insecure_port('127.0.0.1:8001')
    server.start()
    server.wait_for_termination()

client.py

from proto import hello_pb2,hello_pb2_grpc
import grpc

if __name__ == '__main__':
	with grpc.insecure_channel("127.0.0.1:80001') as channel:
		# 建立连接通道
		# 拿到服务对象
		stub = hello_pb2_grpc.GreeterStub(channel)
		
		# rsp: hello_pb2.HelloResponse 类型描述
		# 拿到调用的返回值
		rsp: hello_pb2.HelloResponse = stub.SayHello(hello_pb2.HelloRequest(name='zzz'))
		
		print(rsp.name)
  网络协议 最新文章
使用Easyswoole 搭建简单的Websoket服务
常见的数据通信方式有哪些?
Openssl 1024bit RSA算法---公私钥获取和处
HTTPS协议的密钥交换流程
《小白WEB安全入门》03. 漏洞篇
HttpRunner4.x 安装与使用
2021-07-04
手写RPC学习笔记
K8S高可用版本部署
mySQL计算IP地址范围
上一篇文章      下一篇文章      查看所有文章
加:2022-03-16 22:56:30  更:2022-03-16 22:57:01 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/3 0:10:52-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码