0

我有一个 gRPC 客户端集成,它接收大小约为 65MB 的消息(主要是日期 x 时间元组数组)。反序列化收到的消息似乎在初始请求上分配了大约 700MB 的额外非托管内存。随后的相同请求不再增加总进程内存消耗。

这正常吗?任何想法如何弄清楚发生了什么,甚至更好地控制它?

4

1 回答 1

0

这似乎与在异步上下文中接收数据有关。不知何故,任务调度程序保留了转换后的消息有效负载的任务。在调用 gRPC 客户端的异步方法末尾添加 aTask.Yield()似乎可以解决它。

检查此讨论: https ://github.com/grpc/grpc-dotnet/issues/1267

于 2021-04-14T11:09:49.533 回答