A simplistic spring-web component that automatically configures spring-mvc controllers that transcodes HTTP requests, invokes corresponding gRPC service method and transcodes the reply back to HTTP response, with little configuration. Inspired by envoy HTTP to gRPC transcoder.
Show me how: refer to the module example with its tests.
Maven:
<dependency>
<groupId>io.github.kenix</groupId>
<artifactId>http-grpc-spring-web</artifactId>
<version>0.1.0-rc.4</version>
</dependency>
Gradle:
dependencies {
implementation 'io.github.kenix:http-grpc-spring-web:0.1.0-rc.4'
}
After implementing a gRPC service, provide following beans:
HttpGrpcMapper
responsible for discovering gRPC services and registering transcoder controllers
GrpcServerDescriptor
used by HttpGrpcMapper
to discover gRPC services. Currently, only support single server. If necessary, can easily support multiple servers.
-
List<FileDescriptor>
is mandatory in order to find all message types of gRPC requests. TODO: either injection or enabling ProtoReflectionService -
one of following alternatives:
-
List<ServerMethodDefinition>
transcoded call is made directly -
gRPC server port and one of following:
- a gRPC global server interceptor
ServerMethodDefinitionInterceptor
and enabling gRPCHealthService
Invoked the first time (service health check) it will collect allServerMethodDefinition
s, after that only forward calls. This enables direct transcoded calls. - nothing else, transcoded call will not be direct, but routed internally using an embedded gRPC client. This has performance impact.
- a gRPC global server interceptor
-
- distributed tracing: out of the box with
spring-cloud-starter-sleuth
, see also module client
Refer to open issues.