文件描述符:一个整数如何连接进程与内核的四十年演进
“Too many open files” 凌晨三点,生产环境的服务器突然告警。Nginx无法接受新连接,应用日志里满是EMFILE错误。运维检查后发现,某个Java进程打开了超过一百万个文件描述符——虽然系统配置允许这样做,但进程的资源限制仍然是默认的1024。 ...
“Too many open files” 凌晨三点,生产环境的服务器突然告警。Nginx无法接受新连接,应用日志里满是EMFILE错误。运维检查后发现,某个Java进程打开了超过一百万个文件描述符——虽然系统配置允许这样做,但进程的资源限制仍然是默认的1024。 ...
2024年4月,Amazon EKS的一个GitHub issue报告了一个诡异现象:Elixir应用容器频繁被OOMKilled,但监控显示容器的内存使用量远低于限制。排查发现,真正的元凶是容器被配置了过高的文件描述符限制(1048576),每个文件描述符在内核中都会分配相应的数据结构,累积起来消耗了大量的内核内存,最终触发了OOM Killer。 ...