应用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,第一时间接收我的原创技术文章,谢谢大家的阅读。

相关推荐
白衣鸽子4 分钟前
【基础数据篇】数据遍历大师:Iterator模式
后端·设计模式
用户4099322502127 分钟前
想抓PostgreSQL里的慢SQL?pg_stat_statements基础黑匣子和pg_stat_monitor时间窗,谁能帮你更准揪出性能小偷?
后端·ai编程·trae
货拉拉技术12 分钟前
网关 MCP 转换技术:从实现到平台落地
java·架构·mcp
艾菜籽13 分钟前
SpringMVC练习:加法计算器与登录
java·spring boot·spring·mvc
xuejianxinokok15 分钟前
什么是代数类型 ? java为什么要添加record,Sealed class 和增强switch ?
后端·rust
洛小豆15 分钟前
Git打标签仓库看不到?她说:豆子,你又忘了加 --tags!
git·后端·github
LawsonJin41 分钟前
springboot实现微信小程序支付(服务商和普通商户模式)
spring boot·后端·微信小程序
浮游本尊1 小时前
Java学习第25天 - Spring Cloud Alibaba微服务生态
java
Cg136269159741 小时前
Super的详解
java
毕设源码-朱学姐1 小时前
【开题答辩全过程】以 便利店库存管理系统为例,包含答辩的问题和答案
java·eclipse