为何内存不够用?微服务改造启动多个 SpringBoot 的陷阱与解决方案
共 3255字,需浏览 7分钟
·
2024-06-22 13:49
阅读本文大概需要 2.8 分钟。
来自:juejin.cn/post/7303862023618707491
以下是正文。
背景简述
解决步骤
-
最大堆大小(-Xmx):通常为物理内存的1/4。 -
初始堆大小(-Xms):通常为物理内存的1/64。
默认堆大小
客户端 JVM 默认初始和最大堆大小
服务器 JVM 默认初始和最大堆大小
复盘
-
检查JVM参数: 如果在生产环境中启动Spring Boot没有设置JVM参数,使用默认的JVM配置,可能会导致性能问题和资源浪费。优化JVM参数,根据应用程序的需求和服务器配置进行调整。 -
观察内存使用情况: 使用监控工具或者操作系统提供的工具,观察Java应用的内存使用情况,包括堆内存、非堆内存、垃圾回收等。 -
分析GC: 如果发现内存问题,可以分析GC日志以了解垃圾回收的情况,包括频率、时间等。 -
合理设置堆内存大小: 根据应用程序的需求和服务器的物理内存,合理设置堆内存的大小,避免过大或过小导致性能问题。 -
考虑使用内存分析工具: 使用工具如VisualVM、MAT等,对应用程序进行内存分析,找出可能存在的内存泄漏或者大对象。
-
默认的JVM配置可能不适合你的应用程序的性能需求和资源限制,导致内存溢出、垃圾回收频繁、性能下降等问题。
-
默认的JVM配置可能会浪费服务器的内存资源,因为JVM会根据物理内存的大小来分配堆内存的大小,而不是根据应用程序的实际需求。
推荐阅读:
程序员在线工具站:cxytools.com
推荐一个我自己写的工具站:http://cxytools.com,专为程序员设计,包括时间日期、JSON处理、SQL格式化、随机字符串生成、UUID生成、随机数生成、文本Hash...等功能,提升开发效率。
⬇戳阅读原文直达! 朕已阅 
评论
