Grpc原理

作者: wesper_428f | 来源:发表于2019-02-15 16:25 被阅读1253次

1 rpc框架原理

rpc调用原理框架如图:


image.png

2 业内比较成熟的rpc框架

支持多语言的主要分为3类

-支持多语言的rpc框架,例如Google的grpc,facebook thrift, 百度的brpc
-支持特定语言的rpc框架, 例如新浪微博的Motan
-支持服务治理微服务化特性框架,其底层仍是rpc框架,例如 阿里的Dubbo
目前业内主要使用基于多语言的 RPC 框架来构建微服务,是一种比较好的技术选择,例如netflix ,API服务编排层和后端微服务之间采用微服务rpc进行通信

3 GRPC框架介绍

-支持C java js
-git地址 https://github.com/grpc/grpc-java
-原理图:

image.png

4 GRPC服务端创建流程

  1. NettyServer的创建,gRpc服务端的创建,初始化nettyServer,nettyServer负责监听socket地址,实习基于HTTP2协议的写入
  2. 绑定IDL定义服务接口实现类,grpc和一些RPC框架的不同是,服务的接口实现类并不是同过反射实现的,而是通过proto工具生成的代码,服务启动后,将服务的接口实现类注册到gRpc内部的服务注册中心上,请求消息来后,便可以通过服务名和方法名调用 ,直接调用启动的时候注册的服务实例,bu不需要反射进行调用,性能更优
  3. ServerImpl 负责整个 gRPC 服务端消息的调度和处理,创建 ServerImpl 实例过程中,会对服务端依赖的对象进行初始化,例如 Netty 的线程池资源,gRPC 的线程池、内部的服务注册类(InternalHandlerRegistry)


    image.png

4.1 gRpc消息接入流程

  1. gRPC消息由netty /http/2 协议负责接入,通过grpc 注册的Http2Framelister将解码后的Http header和Http body 发送到gRPC的NettyServerHandler ,实现netty http/2的消息接入

    gRPC 请求消息接入流程如下: image.png

4.2 gRPC消息响应模型

4.3 Netty Server 线程模型

gRPC 的线程模型遵循 Netty 的线程分工原则,即:协议层消息的接收和编解码由 Netty 的 I/O(NioEventLoop) 线程负责;后续应用层的处理由应用线程负责,防止由于应用处理耗时而阻塞 Netty 的 I/O 线程
不过正是因为有了分工原则,grpc 之间会做频繁的线程切换,如果在一次grpc调用过程中,做了多次I/O线程到应用线程之间的切换,会导致性能的下降,这也是为什么grpc在一些私有协议支持不太友好的原因

gRpc 的线程模型

1. BIO线程模型 ,例如tomcat的BIO线程模型

image.png

缺点

改进:
优化后BIO线程模型采用了线程池的做法但是后端的应用处理线程仍然采用同步阻塞的模型,阻塞的时间取决对方I/O处理的速度和网络I/O传输的速度

2 异步非阻塞的线程模型

grpc的线程模型主要包含服务端线程模型,客户端线程模型

服务端线程模型主要包括

  1. 服务端的写入,客户端的接入线程(HTTP/2 Acceptor)
  2. 网络I/O的读写线程
  3. 服务接口调用线程

客户端线程模型主要包含

  1. 客户端的链接 (HTTP/2 Connector)
  2. 网络I/O读写线程
  3. 接口调用线程
  4. 响应回调通知线程

2.1服务调度线程模型

2.1.1 I/O 通信线程模型
gRPC的做法是服务监听线程和I/O线程分离Reactor多个线程模型 其工作原理如下:


image.png

2.1.2 服务调度线程模型

2.2客户端线程模型概述

gRPC 客户端线程模型工作原理如下图所示(同步阻塞调用为例)

image.png

2.2.1 I/O 通信线程模型

相比于服务端,客户端的线程模型简单一些,它的工作原理如下:

image.png

2.2.2 客户端调用线程模型

image.png

grpc 线程模型

相关文章

  • grpc和consul结合实现分布式rpc调用

    # GRPC > 主要介绍了grpc在使用示例和原理,以及如何与consul结合 ## gRPC 是什么? > g...

  • grpc原理

    RPC 框架原理 RPC 框架的目标就是让远程服务调用更加简单、透明,RPC 框架负责屏蔽底层的传输方式(TCP ...

  • Grpc原理

    1 rpc框架原理 rpc调用原理框架如图: 2 业内比较成熟的rpc框架 支持多语言的主要分为3类 -支持多语言...

  • GRPC 浅析

    原理: GRPC原理解析 IDL(proto buffer) + RPCnetty:异步/事件驱动的 网络应用程序...

  • 使用grpcui测试gRPC服务

    grpcui类似Swagger UI,可以用来测试gRPC服务,使用起来特别简单。 其原理是通过自动发现gRPC服...

  • iOS gRPC 初步探索

    下面让我来具体说说,gRPC的简单原理和使用方法,最重要的是踩过的坑 一、何为gRPC gRPC 是一个高性能、开...

  • 4 grpc的原理

    1 rpc流 客户端调用 sub构建消息 http2网络连接 将消息传递给服务端骨架 2 pb编码消息 pb的编码...

  • grpc-源码-网络模型

    golang 的grpc库是 https://github.com/grpc/grpc-go grpc serve...

  • gRPC 4种rpc定义方法与3种stub介绍

    gRPC 有关gRPC官方介绍(https://www.grpc.io/docs/what-is-grpc/int...

  • gRPC安装与编译

    1.安装gRPC grpc与protobuf版本对照表:https://github.com/grpc/grpc/...

网友评论

    本文标题:Grpc原理

    本文链接:https://www.haomeiwen.com/subject/pltwkqtx.html