上文给大家详细介绍了在
Apinto 上实现
HTTP

gRPC
的协议转换

的基本内容,本篇我们将继续讲解如何在 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 插件

7.png

填写完后提交即可。


验证协议转换请求

1. 启动 gRPC 服务器

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

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


  • HelloRequest
    中的
    name
    字段通过
    HelloResponse

    msg
    字段封装成
    hello,%s
    的结果返回;

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

调用结果如下:


欢迎到 GitHub 体验

标签: none

添加新评论