Java heap space

编辑
  • 文档创建者:文档助手1
  • 浏览次数:8740次
  • 编辑次数:9次
  • 最近更新:Kevin-s 于 2019-06-17
  • 1. 描述

    当从数据库中查询大量的数据,每个模板取出来几百万条数据,或者是频繁的刷新项目、模板时就会占用 Java 虚拟机 JVM 的大量内存,超过内存就会出现报java.lang.OutOfMemoryError:Java heap space 内存溢出的错误,具体报错如下:

    2. 原因

    由于服务器的 JVM 不够用而抛出的错误,JVM 在启动的时候会自动设置 heap size 的值,初始空间(即-Xms)是物理内存的 1/64,最大空间(-Xmx)是物理内存的 1/4。所以可以根据自己的情况进行修改 JVM 的 -Xmn -Xms -Xmx 等选项。


    2.1 内存大小设置

    当 heap size 设置偏小,除了报异常信息外,还会发现执行报表的速度变慢了。

    注:heap size 最大不要超过可用物理内存的 80%,一般的要将 -Xms 和 -Xmx 选项设置为相同,而 -Xmn为1/4 的 -Xmx 值。heap size 的 -Xms -Xmn 设置不要超出物理内存的大小。否则会提示“Error occurred during initialization of VM Could not reserve enough space for object heap”

    3. 解决方案

    3.1 调大服务器的内存

    服务器的内存修改可以参考 服务器内存修改 文档。


    3.2 启用磁盘缓存

    我们默认使用的是内存缓存,就是取出的数据全部放在服务器内存中,此时若数据量大的情况下就很可能会导致内存不够用,改为磁盘缓存,就是将取出的数据部分放在内存中,部分放在磁盘中,这样可以减少服务器内存占用,但是从磁盘中读取数据会造成取数效率下降,增长时间的。

    具体的操作可查看 数据集缓存与共享 的缓存至磁盘小节。


    附件列表


    主题: 性能优化
    标签: 暂无标签 编辑/添加标签
    如果您认为本文档还有待完善,请编辑

    文档内容仅供参考,如果你需要获取更多帮助,付费/准付费客户请咨询帆软技术支持
    关于技术问题,您还可以前往帆软社区,点击顶部搜索框旁边的提问按钮
    若您还有其他非技术类问题,可以联系帆软传说哥(qq:1745114201

    此页面有帮助吗?只是浏览 [ 去社区提问 ]