Go 服务被 OOMKilled,别先怪 GC
服务又被 OOMKilled 了。
Pod 刚重启,群里已经有人开始翻 GC 日志。有人说 GC CPU 到了 20%,有人说把 GOGC 调低一点,还有人建议直接上 GOMEMLIMIT。
这些动作不一定错,但顺序错了。 …
服务又被 OOMKilled 了。
Pod 刚重启,群里已经有人开始翻 GC 日志。有人说 GC CPU 到了 20%,有人说把 GOGC 调低一点,还有人建议直接上 GOMEMLIMIT。
这些动作不一定错,但顺序错了。 …
服务 p99 每隔几十秒抖一下。
监控里 GC CPU 大概 5%,不算夸张,但曲线很准:GC 一来,延迟就往上冒。群里很快有人提议:把 GOGC 从 100 调到 200,先让 GC 少跑几次。
这个动作看起来很合理。
CPU 下来了 …
服务内存从 800MB 慢慢涨到 2.6GB。
曲线不陡,不像雪崩。它只是每天往上爬一点,重启以后掉下来,过几天又回到老地方。告警响了,群里第一句话通常是:是不是内存泄漏?
这个判断不算错,但太急。
在 Go 服务里,内存持续上涨可能是真泄 …
凌晨两点,线上服务突然变慢。
你登上服务器,top 一看:CPU 占用 30%,内存也没满,磁盘 IO 正常。但请求就是卡,P99 从 50ms 跳到 800ms。
第一反应:加机器?
先别急。系统给你的信号不是"资源不够 …
| |
问你一个问题:这个 x 是在堆上还是在栈上?
如果你答"栈上",你错了——至少在这段 …
很多人觉得 Redis 没什么门槛。
命令不难,接入也快,压测时还总能打出很漂亮的数字。于是项目上线后,大家默认它“应该不会出事”。
但我看过不少 Redis 问题,最后都不是 Redis 自己不行,而是前面的设计太随便:Key 怎么拆 …
2024年对于前端开发者来说是一个充满机遇的年份。随着Web技术的快速发展,新的框架、工具和最佳实践不断涌现。本文将深入分析今年前端开发的主要趋势,帮助开发者把握技术发展方向。