BT

如何利用碎片时间提升技术认知与能力? 点击获取答案

内存限制自适应,容器中运行Java 9效果更出众

| 作者 Abraham Marín Pérez 关注 8 他的粉丝 ,译者 大愚若智 关注 9 他的粉丝 发布于 2017年2月24日. 估计阅读时间: 3 分钟 | 都知道硅谷人工智能做的好,你知道 硅谷的运维技术 也值得参考吗?QCon上海带你探索其中的奥义

OpenJDK 9中首次新增了一项实验性功能,JVM可借助该功能检测到自己运行在容器中,进而酌情调整内存限制。尽管过去几年来容器技术日渐流行,但包括JVM在内的很多工具依然需要通过宿主机的参数访问可用资源,经常会遇到内存不足的情况,并会显示各种令人困惑的错误信息。与Java 9一同发布的该功能正是为了在多种使用场景中避免出现此类问题而生。

诸如DockerHerokuKubernetes等容器技术实际上是一种基于Linux操作系统的轻量级虚拟机。这种虚拟机的空间占用更低,意味着可以在消耗更少资源的情况下,更快速地提供与传统虚拟机极为类似的功能,但这种做法也有不足之处:传统虚拟机更成熟,可模拟一整套专用硬件,并可确保大部分现有软件可以按照预期结果运行;但容器技术使用了宿主机的硬件和操作系统,这意味着需要依赖宿主机相关信息的软件在运行过程中可能无法感知容器本身所造成的额外局限。Netflix公司Linux容器服务(也叫做Titus)部门开发者Fabio Kung在2014年撰文介绍了这一情况,虽然时至今日,那篇文章中的部分内容已经有些过时,但依然可以帮助我们充分了解这个问题。

JVM也曾饱受这个问题困扰。如果不使用-Xmx指定内存上限,JVM会将上限设置为物理内存数的一小部分(通常为1/4,但情况可能各异),而这一结果甚至还没有考虑到容器本身所造成的限制。Java 9中新增的这项功能可以判断JVM是否运行在Control Group,即cgroup中(这是一种Linux技术,大部分容器会通过该技术对硬件和其他资源的使用施加强制限制),借此预防出现类似的问题。如果JVM检测到自己运行在cgroup中,随后会试图确定cgroup所定义的内存限制,将该限制视作可用物理内存总量,并将其他每个参数设置为该值的一部分。这依然是一个实验性功能,只有通过-XX:+UseCGroupMemoryLimitForHeap选项激活后方能生效。

Cgroups最早在2008年被纳入Linux内核,并在2013年进行了重新设计,该技术可对资源的使用进行隔离,让应用程序对内存、CPU、IO、网络等资源的访问进行控制。不同应用程序可创建自己的Control Group层次结构,并给每个Group应用不同的限制,这意味着应用程序无法事先知道自己要运行在哪个Group中。也正是因此,JVM只能根据cgroup和可能应用的内存限制进行猜测。

查看英文原文Java 9 Will Adjust Memory Limits if Running with Docker

评价本文

专业度
风格

您好,朋友!

您需要 注册一个InfoQ账号 或者 才能进行评论。在您完成注册后还需要进行一些设置。

获得来自InfoQ的更多体验。

告诉我们您的想法

允许的HTML标签: a,b,br,blockquote,i,li,pre,u,ul,p

当有人回复此评论时请E-mail通知我
社区评论

允许的HTML标签: a,b,br,blockquote,i,li,pre,u,ul,p

当有人回复此评论时请E-mail通知我

允许的HTML标签: a,b,br,blockquote,i,li,pre,u,ul,p

当有人回复此评论时请E-mail通知我

讨论

登陆InfoQ,与你最关心的话题互动。


找回密码....

Follow

关注你最喜爱的话题和作者

快速浏览网站内你所感兴趣话题的精选内容。

Like

内容自由定制

选择想要阅读的主题和喜爱的作者定制自己的新闻源。

Notifications

获取更新

设置通知机制以获取内容更新对您而言是否重要

BT