我在C#中使用gRPC客户端并使用长期双工流。但是,TCP连接在某个时间关闭,因此我想在客户端使用keepalive。服务器(用Go编写)已经为keepalive正确配置,并且已经使用Go编写的客户端进行了测试。
我使用以下代码将keepalive设置为5分钟,并启用跟踪以查看所有传入/传出字节。
Environment.SetEnvironmentVariable("GRPC_TRACE", "tcp,channel,http,secure_endpoint");
Environment.SetEnvironmentVariable("GRPC_VERBOSITY", "DEBUG");
var callCredentials = CallCredentials.FromInterceptor(Interceptor());
var roots = Encoding.UTF8.GetString(Resources.roots);
Channel = new Channel(address, ChannelCredentials.Create(new SslCredentials(roots), callCredentials), new[]
{
new ChannelOption("grpc.keepalive_time_ms", 5 * 60 * 1000), // 5 minutes
});
await Channel.ConnectAsync(DateTime.UtcNow.AddSeconds(5));
但是,在日志中,在5分钟内没有发送字节,并且连接已关闭,因为在流已空闲一段时间后,我无法再通过相同的流发送/接收消息。
如何正确启用keepalive?
答案 0 :(得分:2)
尝试在客户端中添加以下ChannelOption。
new ChannelOption("grpc.keepalive_permit_without_calls", 1)