grpc-java uses an executor in its ServerBuilder
, which if not defined by the builder.executor()
method, uses a static cached thread pool by default. What is the exact use of this executor? Does it just execute the handler methods or does it do “something else” as well?
Also, how does grpc define the netty worker EventLoopGroup
? Specifically, I want to know how the worker threads are assigned to this worker group. Is there a default for the number of threads, or is it a function of the number of cores of the machine? Also, in relation to the above question, how do these netty workers work with the executor? Do they handle just the I/O - reading and writing to the channel?
Edit: Netty, by default creates (2 * number of cores) worker threads.
The executor takes the messages and passes them to your ServerCall. Listener which will actually do the processing of the data. By default, gRPC uses a cached thread pool so that it is very easy to get started. However it is strongly recommended you provide your own executor.
Channel – A gRPC channel provides a connection to a gRPC server on a given host and port. Channels are used to create client stubs. The same channel can be used to connect to multiple services running on the same gRPC server. Client stub – gRPC supports two types of client stubs.
This is the StreamObserver containing your logic for how to handle responses. The other is for the outbound direction, which is the StreamObserver instance that gRPC library returns to you when calling the RPC method. This is the StreamObserver that you use to send requests.
The generated class also contains stubs for use by gRPC clients to call methods defined by the service. Each stub wraps a Channel , supplied by the user of the generated code. The stub uses this channel to send RPCs to the service. gRPC Java generates code for three types of stubs: asynchronous, blocking, and future.
The Executor
that you provide is what actually executes the callbacks of the rpc. This frees up the EventLoop
to continue processing data on the connection. When a new message arrives from the network, it is read on the event loop, and then propagated up the stack to the executor. The executor takes the messages and passes them to your ServerCall.Listener
which will actually do the processing of the data.
By default, gRPC uses a cached thread pool so that it is very easy to get started. However it is strongly recommended you provide your own executor. The reason is that the default threadpool behaves badly under load, creating new threads when the rest are busy.
In order to set up the event loop group, you call the workerEventLoopGroup method on NettyServerBuilder. gRPC is not strictly dependent on Netty (other server transports are possible) so the Netty specific builder must be used.
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With