zt3ff3n 发表于 2021-10-10 19:53

GRPC: 如何让 gRPC 提供 Swagger UI?

介绍


本文将介绍如何让一个 gRPC 服务之上提供 Swagger UI。

为了能提供 Swagger UI,我们首先要让 gRPC 提供 Restful API,然后,Swagger UI 才可以访问后台。
为了能让 gRPC 提供 REST API,我们需要使用 grpc-gateway我们需要使用 protoc-gen-openapiv2 从 proto 文件,创建 Swagger UI 所需要的文件
先决条件


使用过 GRPC 的用户都应该知道,protocol buffer 文件需要使用相关的命令行,把 *.proto 文件编译成 *.go 文件。

根据不同需要,会使用到不同的命令行文件。以 Go 语言为例,我们需要大致如下几个命令行文件。
工具介绍安装protobufprotocol buffer 编译所需的命令行Installprotoc-gen-go从 proto 文件,生成 .go 文件Installprotoc-gen-go-grpc从 proto 文件,生成 GRPC 相关的 .go 文件Installprotoc-gen-grpc-gateway从 proto 文件,生成 grpc-gateway 相关的 .go 文件Installprotoc-gen-openapiv2从 proto 文件,生成 swagger 界面所需的参数文件Install
除了安装上述命令行,我们还需要根据需要,运行至少4种不同命令来编译 *.proto 文件,非常晦涩难懂。

具体操作方式可参考我的前一篇文章:【GRPC: 使用 Buf 快速编译 GRPC proto 文件】
或者访问:【https://rkdev.info/cn/docs/bootstrapper/user-guide/grpc-golang/basic/grpc-gateway/】
安装

go get github.com/rookie-ninja/rk-boot快速开始

1.创建 api/v1/greeter.proto

syntax = "proto3";package api.v1;option go_package = "api/v1/greeter";service Greeter {rpc Greeter (GreeterRequest) returns (GreeterResponse) {}}message GreeterRequest {string name = 1;}message GreeterResponse {string message = 1;}2.创建 api/v1/gw_mapping.yaml

type: google.api.Serviceconfig_version: 3# Please refer google.api.Http in https://github.com/googleapis/googleapis/blob/master/google/api/http.proto file for details.http:rules:    - selector: api.v1.Greeter.Greeter      get: /api/v1/greeter3.创建 buf.yaml

version: v1beta1name: github.com/rk-dev/rk-demobuild:roots:    - api4.创建 buf.gen.yaml

version: v1beta1plugins:# protoc-gen-go needs to be installed, generate go files based on proto files- name: go    out: api/gen    opt:   - paths=source_relative# protoc-gen-go-grpc needs to be installed, generate grpc go files based on proto files- name: go-grpc    out: api/gen    opt:      - paths=source_relative      - require_unimplemented_servers=false# protoc-gen-grpc-gateway needs to be installed, generate grpc-gateway go files based on proto files- name: grpc-gateway    out: api/gen    opt:      - paths=source_relative      - grpc_api_configuration=api/v1/gw_mapping.yaml# protoc-gen-openapiv2 needs to be installed, generate swagger config files based on proto files- name: openapiv2    out: api/gen    opt:      - grpc_api_configuration=api/v1/gw_mapping.yaml5.编译 proto file

$ buf generate
如下的文件会被创建。
$ tree api/gen api/gen└── v1    ├── greeter.pb.go    ├── greeter.pb.gw.go    ├── greeter.swagger.json    └── greeter_grpc.pb.go 1 directory, 4 files6.创建 boot.yaml

grpc:- name: greeter                   # Name of grpc entry    port: 8080                      # Port of grpc entry    enabled: true                   # Enable grpc entry    sw:      enabled: true               # Enable swagger      jsonPath: "api/gen/v1"      # Provide swagger config file path7. 创建 main.go

package mainimport (    "context"    "fmt"    "github.com/rookie-ninja/rk-boot"    "github.com/rookie-ninja/rk-demo/api/gen/v1"    "google.golang.org/grpc")// Application entrance.func main() {    // Create a new boot instance.    boot := rkboot.NewBoot()    // ***************************************    // ******* Register GRPC & Gateway *******    // ***************************************    // Get grpc entry with name    grpcEntry := boot.GetGrpcEntry("greeter")    // Register grpc registration function    grpcEntry.AddRegFuncGrpc(registerGreeter)    // Register grpc-gateway registration function    grpcEntry.AddRegFuncGw(greeter.RegisterGreeterHandlerFromEndpoint)    // Bootstrap    boot.Bootstrap(context.Background())    // Wait for shutdown sig    boot.WaitForShutdownSig(context.Background())}// Implementation of func registerGreeter(server *grpc.Server) {    greeter.RegisterGreeterServer(server, &GreeterServer{})}// Implementation of grpc service defined in proto filetype GreeterServer struct{}func (server *GreeterServer) Greeter(ctx context.Context, request *greeter.GreeterRequest) (*greeter.GreeterResponse, error) {    return &greeter.GreeterResponse{      Message: fmt.Sprintf("Hello %s!", request.Name),    }, nil}8.文件夹结构

$ tree.├── api│   ├── gen│   │   └── v1│   │       ├── greeter.pb.go│   │       ├── greeter.pb.gw.go│   │       ├── greeter.swagger.json│   │       └── greeter_grpc.pb.go│   └── v1│       ├── greeter.proto│       └── gw_mapping.yaml├── boot.yaml├── buf.gen.yaml├── buf.yaml├── go.mod├── go.sum└── main.go4 directories, 12 files9.验证


访问 Swagger:http://localhost:8080/sw

swagger.png
页: [1]
查看完整版本: GRPC: 如何让 gRPC 提供 Swagger UI?