我们正在 AWS 中运行基于 openjdk:11-slim 的 docker 容器。我们通常使用两种实例类型。一个有 1G,另一个有 2G 可用内存。在 1G 实例上,我开始使用这些参数来限制堆大小:-XX:MaxRAM=1g -XX:MaxRAMPercentage=30
我也想限制非堆。它是一个 Spring Boot 应用程序,在 Spring Boot Admin 中它当前看起来像这样(默认运行):
正如您所看到的,1.33 GB Max 甚至无法工作,因为总内存只有 1G。理想情况下,非堆也应限制在 30% 以内。我可以使用哪些 JVM 参数来调整非堆内存的大小?
我进行了一些调查,在这个实例中,大约 1G 总 RAM 的 30% 已用于非应用程序相关进程(第三列是总内存的百分比)。
3663 root 4.6 /usr/bin/python2.7 /usr/bin/aws logs push --config-file /etc/awslogs/awslogs.conf --additional-configs-dir /etc/awslogs/config
3430 root 4.1 /usr/bin/dockerd --storage-driver devicemapper --storage-opt dm.thinpooldev=/dev/mapper/docker-docker--pool --storage-opt dm.use_deferred_removal=true --storage-opt dm.use_deferred_deletion=true --storage-opt dm.fs=ext4 --storage-opt dm.basesize=100G
2949 healthd 3.5 puma 2.11.1 (tcp://127.0.0.1:22221) [healthd]
3021 root 2.6 /usr/bin/python2.7 /opt/aws/bin/cfn-hup
3437 root 2.2 containerd --config /var/run/docker/containerd/containerd.toml --log-level info
4867 root 2.1 docker logs -f f82ef403ef45
4831 root 2.0 docker wait f82ef403ef45
3501 root 1.9 docker events
3322 root 1.7 /sbin/dmeventd
16976 root 0.7 sshd: ec2-user [priv]
2280 root 0.6 /usr/bin/amazon-ssm-agent
您不能限制堆外内存,否则应用程序将崩溃。当分配直接内存时,总是需要它,因此拒绝它与OutOfMemoryError
.
您可以限制元空间大小-XX:MaxMetaspaceSize=
.
您可以减少 JIT 编译器用于存储已编译方法的内存量,从而可能减少编译,使用-XX:ReservedCodeCacheSize=
.
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)