在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堆大小
Logo

K8S/Kubernetes社区为您提供最前沿的新闻资讯和知识内容

更多推荐