最近我在调查 Go 应用程序中内存泄漏的问题,这个问题主要因为我没有正确的阅读文档。这是一段导致消耗了多个 Gbs 内存的代码:
以下是应用程序的内存指标图:
<-time.After在计时器触发之前,垃圾收集器不会回收 Timer。
所以 9Gb 的内存被定期垃圾回收变得非常必要了。我们在 channel 中每秒有 60k 个消息,在每个给定时刻分配大约 1800 万个计时器加上一些不确定数字的计时器等待被垃圾回收。
微不足道的重构有助于将内存消耗减少 20 倍,这些都是阅读文档就能解决的问题。
本文由 原创编译, 荣誉推出