【发布时间】:2018-12-20 09:56:58
【问题描述】:
Android grpc 客户端正在接收来自服务器的 GOAWAY,出现“ping 太多”错误。现在我意识到这可能是服务器端的问题,但我认为问题是客户端通道设置与服务器的设置不匹配。
我有一个具有以下设置的 C# gRPC 服务器:
List<ChannelOption> channelOptions = new List<ChannelOption>();
channelOptions.Add(new
ChannelOption("GRPC_ARG_HTTP2_MIN_RECV_PING_INTERVAL_WITHOUT_DATA_MS",
1000));
channelOptions.Add(new
ChannelOption("GRPC_ARG_HTTP2_MAX_PINGS_WITHOUT_DATA", 0));
channelOptions.Add(new
ChannelOption("GRPC_ARG_KEEPALIVE_PERMIT_WITHOUT_CALLS", 1));
this.server = new Server(channelOptions) {
Services = { TerminalService.BindService(this) },
Ports = {new ServerPort("0.0.0.0", 5000,
ServerCredentials.Insecure)}
};
在 Android 上,我有以下频道设置:
private val channel = ManagedChannelBuilder.forAddress(name, port)
.usePlaintext()
.keepAliveTime(10, TimeUnit.SECONDS)
.keepAliveWithoutCalls(true)
.build()
几分钟后(但似乎是随机时间)。我得到了goaway错误。我注意到,如果我在通话中流式传输数据,那么错误就永远不会发生。仅当流上没有数据时。这让我相信问题是 GRPC_ARG_HTTP2_MAX_PINGS_WITHOUT_DATA 也需要在 Android 客户端上设置。问题是我一生都找不到在 gRPC java 上设置这些通道设置的位置。有人可以指出我可以在哪里设置这些频道设置吗?没有设置这些的示例。
【问题讨论】:
标签: android grpc keep-alive grpc-java