应用OutOfMemoryError了,还能正常处理请求吗?

更多干货文章和福利在我的公众号:Hoeller,欢迎大家关注并联系我,一起探讨技术呀...

如果应用出现了OutOfMemoryError,应用还能正常工作吗?

单纯考虑Java其实是可以的 ,因为本质上当某次请求出现OutOfMemoryError时,只是表示JVM剩余可用内存小于该请求所需的内存 ,所以抛出OutOfMemoryError,但是如果其他请求所需要的内存比较小,JVM能够满足,那么JVM还是能继续处理其他请求的。

但是,如果在Linux中有一个机制:OOM killer(Out Of Memory killer) ,该机制会监控操作系统中内存占用过高的进程,操作系统一旦发现系统内存不足了,就会把占用内存最高的进程给kill掉。所以Java进程当出现OutOfMemoryError时,可能会触发OOM killer机制,从而被操作系统给kill掉,导致不能对外提供服务了。

比如,我有以下Controller:

每访问一次/test,就会消耗100m内存,但是访问/hello则基本不需要消耗内存。

指定-Xms200m -Xmx200m参数运行项目,第一次访问/test正常返回,第二次访问/test就会抛OutOfMemoryError了,只要抛了OutOfMemoryError就表示此次请求没有消耗掉内存(因为内存不够它消耗),此时程序仍然在运行中,此时访问/hello能正常得到结果。

接下来,我们来验证OOM killer机制 ,把上述SpringBoot应用打成可执行Jar并上传到阿里云服务器上,服务器内存为512m,通过运行以下命令启动程序:

第一次访问test正常得到结果,第二次访问test时Java进程就直接被kill掉了,截图为:

所以,在给Java程序设置内存参数时,不能设置得太大,不然很有可能就被操作系统给kill掉了

好啦,关于OutOfMemoryError就介绍到这啦,下次继续分享关于JVM的知识,欢迎大家关注我的公众号:Hoeller,第一时间接收我的原创技术文章,谢谢大家的阅读。

相关推荐
一只叫煤球的猫8 小时前
写代码很6,面试秒变菜鸟?不卖课,面试官视角走心探讨
前端·后端·面试
bobz9659 小时前
tcp/ip 中的多路复用
后端
bobz9659 小时前
tls ingress 简单记录
后端
皮皮林55110 小时前
IDEA 源码阅读利器,你居然还不会?
java·intellij idea
你的人类朋友10 小时前
什么是OpenSSL
后端·安全·程序员
bobz96510 小时前
mcp 直接操作浏览器
后端
前端小张同学13 小时前
服务器部署 gitlab 占用空间太大怎么办,优化思路。
后端
databook13 小时前
Manim实现闪光轨迹特效
后端·python·动效
武子康13 小时前
大数据-98 Spark 从 DStream 到 Structured Streaming:Spark 实时计算的演进
大数据·后端·spark
该用户已不存在14 小时前
6个值得收藏的.NET ORM 框架
前端·后端·.net