美文网首页
如何在 Apinto 实现 HTTP 与gRPC 的协议转换 (

如何在 Apinto 实现 HTTP 与gRPC 的协议转换 (

作者: eolink的小E | 来源:发表于2023-03-16 17:27 被阅读0次

上文给大家详细介绍了在 Apinto 上实现 HTTPgRPC 的协议转换的基本内容,本篇我们将继续讲解如何在 Apinto-Dashboard 中进行配置。

配置 Apinto

Apinto 上我们提供了可视化界面工具 Apinto-Dashboard,以降低初学者的使用成本,以下操作均在 Apinto-Dashboard 中进行配置。

1. 在全局插件中新建 http_to_grpc 插件

2. 创建 gRPC 服务

在这里,我们配置 gRPC服务的相关信息,我们可以配置多个静态负载地址,这里我们填写了 127.0.0.1:9001

3.创建 http 路由,绑定 grpc_demo 上游服务

4. 在路由中绑定 http_to_grpc 插件

由于 gRPC 服务端示例中,我们开启了gRPC反射,因此,在配置插件时,开启反射按钮即可

注:

  • 当服务名称不填时,则默认使用 HTTP 请求路径的第一个/ 和第二个 / 之间的值作为服务名;

  • 当方法名称不填时,则默认使用 HTTP 请求路径的第二个 / 和第三个 / 之间的值作为服务名;
    ·即,若 HTTP 请求路径上 /Service.Hello/Hello ,则此时服务名称为 Service.Hello ,方法名称为 Hello

关于 Protobuf 编码器

gRPC未开启反射,我们需要先新建一个Protobuf 编码器,绑定 http_to_grpc 插件时,绑定对应的编码器 ID 即可,详细步骤如下:

1. 创建 Protobuf 编码器

2. 在路由中绑定 http_to_grpc 插件

填写完后提交即可。

验证协议转换请求

1. 启动 gRPC 服务器

2.请求 Service.Hello 服务的 Hello 方法

在上文中,我们定义了 Hello 方法的功能:

  • HelloRequest 中的 name 字段通过 HelloResponsemsg 字段封装成hello,%s 的结果返回;

  • 将请求的 Header 作为 gRPC 响应的 Trailer 头部返回。

调用结果如下:

写在最后

目前 Apinto 及其周边项目已经开源,我们希望通过 Apinto 强大的插件拓展能力,用户可像乐高积木一样根据需要自行拓展 Apinto 的插件,以满足不同的业务市场需求。

Apinto 目前属于萌芽阶段,我们希望集合广大开源爱好者的力量,与大家一起讨论方案,接受大家的批评指正,一起将产品打磨完善,做下一个端与端间的 Traffic Middleware。

这是一个开放和积极的项目,我们诚挚地邀请您一起参与到我们的项目开源工作中。 每一个贡献都是有意义的,包括但不限于:

  • 查找 bugs,取得性能上的提升
  • 帮助完善文档,提供用户操作体验
  • 提交你们的 issue,让我们知道您的奇思妙想
  • 参与自定义插件的开发,丰富 apinto 的能力

欢迎各位开源爱好者参与到 Apinto 项目中,和我们一起为开源事业贡献自己的力量!

我们希望得到您的关注~

👉 Github : https://github.com/eolinker/apinto

相关文章

  • 深入浅出gRPC

    一、gRPC介绍 gRPC 是在 HTTP/2 之上实现的 RPC 框架,HTTP/2 是第 7 层(应用层)协议...

  • grpc协议解析及新语言支持

    (一)grpc 协议分析。gRPC 是基于 HTTP/2 协议的,要深刻理解 gRPC,理解下 HTTP/2 是必...

  • PowerMock 支持gRPC/HTTP协议,功能丰富的Moc

    PowerMock是一个Mock Server的实现,它同时支持HTTP与gRPC协议接口的Mock,并提供了灵活...

  • gRPC-transport包源码分析

    gRPC是基于HTTP/2标准和proto协议开发的,gRPC的很多特性都依赖于HTTP/2标准提供。gRPC设计...

  • grpc客户端原理

    gRPC 是在 HTTP/2 之上实现的 RPC 框架,HTTP/2 是第 7 层(应用层)协议,它运行在 TCP...

  • 深入了解gRPC:协议

    gRPC 是基于 HTTP/2 协议的,要深刻理解 gRPC,理解下 HTTP/2 是必要的。本篇文章会先简单介绍...

  • gRPC

    gRPC 是 Google 基于 HTTP/2 以及 protobuf 的,要了解 gRPC 协议,只需要知道 g...

  • tcp和http协议

    TCP/IP协议与Http协议的区别 TPC/IP协议是传输层协议,主要解决数据如何在网络中传输,而HTTP是应用...

  • 谈谈Grpc做服务化

    Grpc的介绍 Grpc是由Google主导开发的RPC框架,使用HTTP/2协议并用ProtoBuf作为序列化工...

  • GRPC

    首先,GRPC是基于HTTP2来实现的网络传输协议 使用示例 编写IDL(接口描述语言),通过IDL来定义我们的服...

网友评论

      本文标题:如何在 Apinto 实现 HTTP 与gRPC 的协议转换 (

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