Skip to content

Latest commit

 

History

History
140 lines (88 loc) · 6.31 KB

README.adoc

File metadata and controls

140 lines (88 loc) · 6.31 KB

Vert.x gRPC examples

Here you will find examples demonstrating Vert.x gRPC in action.

Dependencies required

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:vertx-grpc-protoc-plugin plugin that creates server and stub classes for Vert.x.

Each example shows how to use the gRPC request/response API and how to use the stub API.

The protobuf compiler is available for Maven or Gradle and is OS dependant.

Empty exchanges

This example show how to handle RPC calls that do not receive or return data.

Ping Pong exchanges

This example show how to handle RPC calls that send a single object and receive a single object.

Consumer exchange

This example show how to handle RPC calls that do receive an arbitrary stream of response objects.

Producer exchange

This example show how to handle RPC calls that do sends an arbitrary stream of request objects.

Conversational exchange

This example shows how to handle arbitrary streams of request and response objects.

Hello World example

This example is adapted from the gRPC examples.

It shows a simple gRPC service that invokes a service that takes an HelloRequest string wrapper and returns an HelloReply string wrapper.

The gRPC service extends the VertxGreeterGrpc.GreeterImplBase generated class and implements the service logic.

The gRPC client creates an instance of the VertxGreeterGrpc.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

Timeout and deadlines

The Hello World example showing timeout and deadlines in action.

The server is configured to create a deadline when a request with a timeout is received.

It does not send a response purposely to trigger this deadline based on the request timeout.

The client is configured to set a request with a timeout and rely on the server to respond with a deadline exceeded status.

JSON wire format

The Hello World example using JSON wire format instead of Protobuf.

Load balancing

Demonstrate how to use client side load balancing

SSL example

This example is the Hello World example with SSL configuration.

It shows a simple gRPC service that invokes a service that takes an HelloRequest string wrapper and returns an HelloReply string wrapper. The communication uses SSL.

The gRPC service extends the VertxGreeterGrpc.GreeterImplBase generated class and implements the service logic.

The gRPC client creates an instance of the VertxGreeterGrpc.newVertxStub generated class and then use it to invoke the service.

You can run the server and then run the client.