当流调用循环很大时,Grpc 双向流被对等端终止?

问题描述

我在客户端 (dart) 和服务器 (.net) 之间有双向流。客户端有大流调用循环时出现问题

在服务器上我得到

System.IO.IOException: The request stream was aborted.
---> Microsoft.AspNetCore.Connections.ConnectionAbortedException: The HTTP/2 connection faulted.
  --- End of inner exception stack trace ---
  at system.io.pipelines.PipeCompletion.ThrowLatchedException()
  at system.io.pipelines.Pipe.GetReadResult(ReadResult& result)
  at system.io.pipelines.Pipe.GetReadAsyncResult()
  at Microsoft.AspNetCore.Server.Kestrel.Core.Internal.Http2.Http2MessageBody.ReadAsync(CancellationToken cancellationToken)
  at Grpc.AspNetCore.Server.Internal.PipeExtensions.ReadStreamMessageAsync[T](PipeReader input,HttpContextServerCallContext serverCallContext,Func`2 deserializer,CancellationToken cancellationToken)

在客户端我得到

gRPC Error (code: 2,codeName: UNKNowN,message: HTTP/2 error: Stream error: Stream was terminated by peer (errorCode: 2).,details: null)

它在小流调用循环时工作。

我试图增加 MaxStreamsPerConnection 但仍然没有工作

.ConfigureWebHostDefaults(webBuilder =>
                {
                    webBuilder.ConfigureKestrel(serveroption => {
        
                        serveroption.Limits.Http2.MaxStreamsPerConnection = 5000;
                    }).UseStartup<Startup>();
                });

解决方法

我的应用程序使用 nginx 作为反向代理。原来是 nginx 网络服务器的问题。 我从 nginx 得到的错误

client intended to send too large chunked body: 10489464 bytes while sending request to upstream,

要解决这个问题,只需添加

http {
    ...
    client_max_body_size 20M;
}   

Nginx error: client intended to send too large body