其初始空间(即-xms)是物理内存的1/64,最大空间(-xmx)是物理内存的1/4。
可以利用jvm提供的-xmn -xms -xmx等选项可进行设置
实例,以下给出1g内存环境下java jvm 的参数设置参考:
linux:
在/usr/local/apache-tomcat-5.5.23/bin目录下的catalina.sh
添加:java_opts='-xms512m -xmx1024m'
要加“m”说明是mb,否则就是kb了,在启动tomcat时会报内存不足。
-xms:初始值
-xmx:最大值
-xmn:最小值
windows
在catalina.bat最前面加入
但是如果不是执行startup.bat启动tomcat而是利用windows的系统服务启动tomcat服务,
上面的设置就不生效了,
就是说set java_opts=-xms128m -xmx350m 没起作用.
上面分配200m内存就oom了
windows服务执行的是bin/tomcat.exe.他读取注册表中的值,而不是catalina.bat的设置.
解决办法:
原值为
重起tomcat服务,设置生效
(tomcat 5.5 的话,在apache software foundation下有个procrun 2.0的 tomcat5/parameters/java下
设置jvmms和jvmmx的值就可以了,要修改10进制的值哦)
不过,os对内存也有限制
附:如何获得jvm的最大可用内存
在命令行下用 java -xmxxxxxm -version 命令来进行测试,然后逐渐的增大xxxx的值,如果执行正常就表示指定的内存大小可用,否则会打印错误信息。
实际发现版本上有细微差别的jdk最大容许内存值都不尽相同,因此在实际的应用中还是要自己试验一下看到底内存能达到什么样的值。
通过这个表想说明的是,如果你的机器的内存太多的话,只能通过多运行几个实例来提供机器的利用率了,例如跑tomcat,你可以多装几个tomcat并做集群,依此类推。
这个人家测试的结果,我这里引用一下
公司 jvm版本 最大内存(兆)client 最大内存(兆)server
所以跟os的系统版本,jdk版本有很大的关系。要是希望充分利用内存,就考虑使用集群。
一、在tomcat的catalina.bat中修改,加入-dcom.sun.management.jmxremote参数
二、需要使用jdk5.0以上,打开bin目录下的jconsole.exe,即可连接跟踪tomcat的内存使用情况
如对本文有疑问, 点击进行留言回复!!
荐 深入理解Java中的BigInteger和 BigDecimal,再也不怕面试了
tomact正常启动,但是在日志文件报错java.lang.NoClassDefFoundError: java/util/logging/Logger
servlet整合quartz:servlet中使用quartz,服务器启动时加载任务
荐 Java——集合中的Map接口通过HashMap类实现一些常用的方法
SpringBoot整合mybatis访问时报错Invalid bound statement (not found)
网友评论