GRPC 连接状态侦听器 Java



我很感兴趣 - 我可以有一些关于GRPC客户端/服务器的连接/断开连接事件的通知吗? 现在,当客户端终止与服务器的连接时,我在服务器上出现异常:

июн 22, 2018 9:34:47 AM io.grpc.netty.NettyServerTransport notifyTerminated
INFO: Transport failed
java.io.IOException: Удаленный хост принудительно разорвал существующее подключение
at sun.nio.ch.SocketDispatcher.read0(Native Method)
at sun.nio.ch.SocketDispatcher.read(SocketDispatcher.java:43)
at sun.nio.ch.IOUtil.readIntoNativeBuffer(IOUtil.java:223)
at sun.nio.ch.IOUtil.read(IOUtil.java:192)
at sun.nio.ch.SocketChannelImpl.read(SocketChannelImpl.java:380)
at io.netty.buffer.PooledUnsafeDirectByteBuf.setBytes(PooledUnsafeDirectByteBuf.java:288)
at io.netty.buffer.AbstractByteBuf.writeBytes(AbstractByteBuf.java:1108)
at io.netty.channel.socket.nio.NioSocketChannel.doReadBytes(NioSocketChannel.java:345)
at io.netty.channel.nio.AbstractNioByteChannel$NioByteUnsafe.read(AbstractNioByteChannel.java:131)
at io.netty.channel.nio.NioEventLoop.processSelectedKey(NioEventLoop.java:645)
at io.netty.channel.nio.NioEventLoop.processSelectedKeysOptimized(NioEventLoop.java:580)
at io.netty.channel.nio.NioEventLoop.processSelectedKeys(NioEventLoop.java:497)
at io.netty.channel.nio.NioEventLoop.run(NioEventLoop.java:459)
at io.netty.util.concurrent.SingleThreadEventExecutor$5.run(SingleThreadEventExecutor.java:886)
at io.netty.util.concurrent.FastThreadLocalRunnable.run(FastThreadLocalRunnable.java:30)
at java.lang.Thread.run(Thread.java:745)

异常翻译:"远程主机强行断开现有连接">

我很感兴趣,如何管理客户端和服务器的连接/断开连接事件?

也许有一些方法可以将我自己的侦听器附加到客户端或服务器?从消息来源我没有弄清楚如何制作它

gRPC 不会故意提供连接级通知。您没有提及您的用例,但绝大多数用例都被负载平衡、代理和 gRPC 的重新连接逻辑破坏了。

有一种方法可以通过ManagedChannel.getState(false)来确定通道是否正常,这对于为用户提供 UI 或告诉其他客户端服务器不正常非常有用。其他用例应基于单个 RPC 构建。

最新更新