在docker中jvm动态使用内存空间限制

在kubernetes中使用spring boot应用,不管pod限制的内存空间多大,jvm默认只使用1GB的空间,会造成业务经常因为内存不足而gc。

而如果我们按照pod的内存空间,在java启动参数中设置xms.xmx的话,之后我们如果要变更pod的资源限制,还要去再修改一次docerfile会很麻烦,也会经常忘记。

所以我们需要设置jvm每次启动都使用pod的内存空间80%来启动。

方式:

  1. 首先java1.8.191支持了docker的适配功能 ,我们所有的运行环境需要1.8.191
  2. 在java的启动参数中加上内容:["java",  "-XX:+UseContainerSupport", "-XX:InitialRAMPercentage=80.0", "-XX:MinRAMPercentage=80.0", "-XX:MaxRAMPercentage=80.0", "-XX:-UseAdaptiveSizePolicy","-jar","package.jar"]
  3. UseAdaptiveSizePolicy表示自动 调节jvm堆大小
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值