Find centralized, trusted content and collaborate around the technologies you use most.
Teams
Q&A for work
Connect and share knowledge within a single location that is structured and easy to search.
我有一个 gRPC 客户端集成,它接收大小约为 65MB 的消息(主要是日期 x 时间元组数组)。反序列化收到的消息似乎在初始请求上分配了大约 700MB 的额外非托管内存。随后的相同请求不再增加总进程内存消耗。
这正常吗?任何想法如何弄清楚发生了什么,甚至更好地控制它?
这似乎与在异步上下文中接收数据有关。不知何故,任务调度程序保留了转换后的消息有效负载的任务。在调用 gRPC 客户端的异步方法末尾添加 aTask.Yield()似乎可以解决它。
Task.Yield()
检查此讨论: https ://github.com/grpc/grpc-dotnet/issues/1267