[转帖]Springboot容器化镜像设置堆内存大小
参考资料:Best Practices: Java Memory Arguments for Containers - DZone Java
有三种方式设置最大堆内存大小:
1. -Xmx
2. -XX:MaxRAMFraction, -XX:MinRAMFraction
3.-XX:MaxRAMPercentage, -XX:MinRAMPercentage
一、-Xmx
这种方式很直接,适用于所有JAVA版本:
java -Xmx512m -jar app.jar
设置最大堆内存大小为512M。
二、-XX:MaxRAMFraction, -XX:MinRAMFraction
只适用于 Java8-131 -190版本(本人未测试该方法)
java -XX:MaxRAMFraction=2 -jar app.jar
按照开头文章中介绍,MaxRAMFraction=2代表将使用容器总内存的1/2作为JVM的最大堆内存。
三、-XX:MaxRAMPercentage, -XX:MinRAMPercentage
适用于Java8-191以上版本(已验证测试)
java -XX:MaxRAMPercentage=70.0 -jar app.jar
MaxRAMPercentage=70.0代表将使用容器的resources.limit.memory值的70%作为JVM的最大堆内存(注意70必须加.0,否则JVM将启动失败:日志里报Improperly specified VM option错误)
四、验证-XX:MaxRAMPercentage过程
Dockerfile中设置MaxRAMPercentage=70.0

测试JDK版本:1.8小版本号为275:

(另:在不使用MaxRAMPercentage参数时,该版本JDK将默认使用1/4的resources.limit.memory作为JVM的堆内存大小)
k8s deployment中resource设置:

JVM堆内存大小:

1.5G * 1024 * 70% 约等于1076MB,符合预期结果。
五、总结
- 根据容器中JDK版本选择合适的方式设置JVM进程堆内存大小
- JDK1.8从191小版本开始,-XX:+UseContainerSupport作为JVM的默认参数,所以假如不配任何堆内存参数,则默认使用容器的1/4作为JVM的堆内存大小
- 不太推荐手动设置-Xmx,每修改一次需要重新打镜像,不如用另外两种方式设置堆内存大小,直接修改resource limit方便
- 建议使用容器的70%内存作为JVM堆内存大小,剩余30%留给堆外内存使用,防止OOM Kill容器
- -XX:MinRAMFraction和-XX:MinRAMPercentage并不是代表设置最小堆内存大小,如果你的容器内存大于250M则使用Maxxxx设置最大堆内存大小,如果小于250M则使用Minxxx设置最大堆内存大小
====================================================================
如有不对的理解,欢迎指正~
[转帖]Springboot容器化镜像设置堆内存大小的更多相关文章
- SpringBoot容器化的多环境配置
SpringBoot容器化的多环境配置 部署通常会有多个环境,如"dev"/"test"/"prod"等环境 容器化部署通常使用环境变量,而 ...
- Heap堆的理解以及在IAR中如何设置堆的大小
文章首发于浩瀚先森博客 堆栈的概念在脑海里已经存在有一段时间了,今天就测试来整理下Heap堆.栈以后再说. 堆区不像全局变量和局部变量总是有指定的内存大小,它是为了在程序运行时动态分配内存而设定的一块 ...
- Tomcat 设置JVM内存大小
我的服务器的配置: # OS specific support. $var _must_ be set to either true or false. JAVA_OPTS="-Xms10 ...
- docker启动 elasticsearch 修改 xmx xms 堆内存大小修改
用docker 安装的elasticsearch 5.6版本默认堆内存最大设置的2G 可以通过如下方法修改 [root@nova-92 logs]# find /var/lib/docker/ -na ...
- RocketMQ_问题_启动报错,修改堆内存大小
1.启动broker报错 虚拟机内存小,导致虚拟机中的JVM内存小,进而在启动broker时分配JVM内存遇到问题 查询网上得知,查看/usr/local/rocketmq-all-4.3.0/dis ...
- 用eclipse运行项目时怎么设置虚拟机内存大小
方法一: 打开eclipse,选择Window--Preferences...在对话框左边的树上双击Java,再双击InstalledJREs,在右边选择前面有对勾的JRE,再单击右边的“Edit”按 ...
- tomcat服务器配置java堆内存大小
我用的是绿色免安装的tomcat,找到tomcat下的bin文件夹下的catalina.bat文件: 编辑该文件,编辑参数,没有的话手动加上: set JAVA_OPTS=-server -Xms51 ...
- 设置共享内存大小 【windows】
hMapFile = CreateFileMapping( INVALID_HANDLE_VALUE, // use paging file NULL, // default security PAG ...
- Linux Tomcat8 启动堆内存溢出
今天在部署一个开源项目的时候,Tomcat8启动异常,报错信息: Exception in thread "RMI TCP Connection(idle)" java.lang. ...
- 【转】JVM 堆内存设置原理
堆内存设置 原理 JVM堆内存分为2块:Permanent Space 和 Heap Space. Permanent 即 持久代(Permanent Generation),主要存放的是Java类定 ...
随机推荐
- 华为云黄瑾:做强坚实数据底座,GaussDB与产业携手共进
近日,华为全球智慧金融峰会2023在上海顺利举行,华为云副总裁.战略与产业发展部总裁黄瑾发表了<做强坚实数据底座,GaussDB与产业携手共进>的主题演讲. 以下为演讲实录: 尊敬的各位来 ...
- 云图说|AI开发难!难!难!端云协同多模态AI开发套件你需要了解一下
摘要:Huawei HiLens Kit是一款端云协同多模态AI开发套件,支持图像.视频.语音等多种数据分析与推理计算,可广泛用于智能监控.智能家庭.机器人.无人机.智慧工业.智慧门店等分析场景. 在 ...
- 想做DBA,多租户管理你一定要知道这些
摘要:多租户为满足客户混合负载处理需求而生,通过提供两层用户机制,分层资源隔离,满足客户对计算和存储资源的自主控制需求. 本文分享自华为云社区<关于GaussDB(DWS)多租户管理,这些你一定 ...
- Python 没有函数重载?如何用装饰器实现函数重载?
摘要:Python 不支持函数重载.当我们定义了多个同名的函数时,后面的函数总是会覆盖前面的函数,因此,在一个命名空间中,每个函数名仅会有一个登记项(entry). 本文分享自华为云社区<为什么 ...
- 论文解读丨LayoutLM: 面向文档理解的文本与版面预训练
摘要:LayoutLM模型利用大规模无标注文档数据集进行文本与版面的联合预训练,在多个下游的文档理解任务上取得了领先的结果. 本文分享自华为云社区<论文解读系列二十五:LayoutLM: 面向文 ...
- 版本升级 | v1.0.11 上线,你的需求被翻牌了吗?
叮咚-综合我们接到的各种用户反馈,OpenSCA 项目组在 1.0.10 的基础上迭代了 1.0.11 版本 升级功能 优化 Java 解析逻辑 支持打印结果概览及常见报错信息到终端界面 支持输出 C ...
- springboot+vue实现 下载服务端返回的文件功能
开发中会遇到,通过浏览器下载服务器端返回的文件功能,本文使用springboot+vue实现该功能. 后端代码: 注:后端返回的文件名遇到中文就会乱码,一直也没得到很好的解决方案,最后就统一返回1.x ...
- vue setup响应式变量
setup响应式变量 一.非响应式变量 1 效果 开发中发现setup()中的变量居然不是响应式的,值得内容变成1了但是页面上还是0 2.源码 二.响应式变量 1.效果 使用ref()可以声明响应式的 ...
- Canvas实现画布的缩放
主要介绍三种方式: 首先创建一个index.html文件 <!DOCTYPE html> <html lang="en"> <head> < ...
- freeswitch服务器的时间同步设置
概述 在生产环境中,一般会有N台freeswitch 服务器,不同服务器之间的信令和话单的时间不能相差太多,否则对查找和定位问题会造成一定的困扰. 同时,freeswitch的默认运行设置并未直接使用 ...