Here you will find examples demonstrating Vert.x gRPC in action.
To use Vert.x gRPC in your own Maven or Gradle project add the following dependency
Group ID: io.vertx Artifact ID: vertx-grpc
You will need to use the com.google.protobuf
plugin to compile the .proto
files.
These examples use the io.vertx:protoc-gen-grpc-java
plugin that creates
server and stub classes for Vert.x, this plugin is an extension of the
io.grpc:protoc-gen-grpc-java
plugin.
The protobuf compiler is available for Maven or Gradle and is OS dependant.
This example show how to handle RPC calls that do not receive or return data.
This example show how to handle RPC calls that send a single object and receive a single object.
This example show how to handle RPC calls that do receive an arbitrary stream of response objects.
This example show how to handle RPC calls that do sends an arbitrary stream of request objects.
This example shows how to handle arbitrary streams of request and response objects.
This example is adapted from the gRPC examples.
It shows a simple gRPC service that invokes a service that
takes takes an HelloRequest
string wrapper and returns an HelloReply
string wrapper.
The gRPC service extends the GreeterGrpc.GreeterVertxImplBase
generated class and
implements the service logic.
The gRPC client creates an instance of the GreeterGrpc.newVertxStub
generated class and
then use it to invoke the service.
You can run the server and then run the client.
You can read more about it on the gRPC website
This example is adapted from the gRPC examples.
This example shows the various kind of gRPC service calls:
-
simple RPC
-
server-side streaming RPC
-
client-side streaming RPC
-
bidirectional streaming RPC
You can run the server and then run the client.
You can read more about it on the gRPC website