java heap space默认值_内存大小设置 Java heap space错误(finereport报表)

本文主要探讨了Java应用在处理大数据查询时可能出现的内存溢出问题,以及服务器线程过多导致的响应能力下降。针对这些问题,提出了调整JVM堆内存设置和启用磁盘缓存的解决方案,并给出了在Tomcat服务器中修改内存配置的步骤。同时,也提到了通过调整服务器线程数来平衡资源利用和响应速度的方法。
摘要由CSDN通过智能技术生成

标签:

1. 问题描述

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

0-1.png

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 调大服务器的内存

下面我们以tomcat为例,来查看下如何修改内存大小。

修改服务器的内存溢出在TOMCAT_HOME\bin\catalina.bat 中添如下代码:

set JAVA_OPTS= -Xmx1024M -Xms512M -XX:MaxPermSize=256m

或者在开始程序 tomcat目录下面的Configure Tomat打开

0-2.png

选择Java设置内存大小

0-3.png

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

3.2 启用磁盘缓存

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

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

1. 问题描述

用户访问某张报表时,服务器就使用一个线程来处理报表运算。

如果访问的人数太多且报表运算量大的话,同一时间争抢服务器cpu线程的人就会很多。服务器响应能力就会减弱,所以我们需要合理控制服务器线程个数。

2. 设置方法

2.1 设置方式

我们可以通过修改Tomcat服务器的配置,来控制线程数。

打开%Tomcat_HOME%/conf/server.xml文档,找到一栏。

在Connector port = "8080"后面加上相应地参数控制线程数,控制参数如下:

minProcessors:最小空闲连接线程数,用于提高系统处理性能,默认值为10

maxProcessors:最大连接线程数,即:并发处理的最大请求数,默认值为75

acceptCount:允许的最大连接数,应大于等于maxProcessors,默认值为100

设置完成后如同:

2.2 注意事项

web server允许的最大连接数还受制于操作系统的内核参数设置,通常Windows是2000个左右,Linux是1000个左右。

这里的连接数是无法直接给出最佳配置的,需要根据您的实际情况,在不断调整,不断测试的基础上,才能到到最合理配置。

标签:

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值