{{ v.name }}
{{ v.cls }}类
{{ v.price }} ¥{{ v.price }}
公司的一个服务器使用tomcat6默认配置,在后台一阵全点击服务器就报废了,查了一下就要是permsize默认值过小造成(16-64)
tomcat_home/bin/catalina.sh
添加一行:java_opts="-xx:permsize=64m-xx:maxpermsize=128m"
问题解决(可能为调用jar包过多原因)下面是网上看到一些设置
java_opts="-server-xms800m-xmx800m-xx:permsize=64m-xx:maxnewsize=256m-xx:maxpermsize=128m-djava.awt.headless=true"
当在对其进行并发测试时,基本上30个user上去就当机了,还要修改默认连接数设置:以下红色四行tomcat6中好相没有,手工加上就可以了,基本上可以解决连接数过大引起的死机。具体数值可跟据实际情况设置
这样设置以后,基本上没有再当机过。。。。。
maxthreads="600"///最大线程数minsparethreads="100"///初始化时创建的线程数maxsparethreads="500"///一旦创建的线程超过这个值,tomcat就会关闭不再需要的socket线程。acceptcount="700"//指定当所有可以使用的处理请求的线程数都被使用时,可以放到处理队列中的请求数,超过这个数的请求将不予处理
----------------------------------------------------------------------------------------------------------------------------------
一、tomcat的jvm提示内存溢出
查看%tomcat_home%logs文件夹下,日志文件是否有内存溢出错误
二、修改tomcat的jvm
1、错误提示:java.lang.outofmemoryerror:javaheapspace
tomcat默认可以使用的内存为128mb,在较大型的应用项目中,这点内存是不够的,有可能导致系统无法运行。常见的问题是报tomcat内存溢出错误,outofmemory(系统内存不足)的异常,从而导致客户端显示500错误,一般调整tomcat的使用内存即可解决此问题。windows环境下修改“%tomcat_home%bincatalina.bat”文件,在文件开头增加如下设置:setjava_opts=-xms256m-xmx512mlinux环境下修改“%tomcat_home%bincatalina.sh”文件,在文件开头增加如下设置:java_opts=’-xms256m-xmx512m’其中,-xms设置初始化内存大小,-xmx设置可以使用的最大内存。
2、错误提示:java.lang.outofmemoryerror:permgenspace
原因:permgenspace的全称是permanentgenerationspace,是指内存的永久保存区域,这块内存主要是被jvm存放class和meta信息的,class在被loader时就会被放到permgenspace中,它和存放类实例(instance)的heap区域不同,gc(garbagecollection)不会在主程序运行期对permgenspace进行清理,所以如果你的应用中有很class的话,就很可能出现permgenspace错误,这种错误常见在web服务器对jsp进行precompile的时候。如果你的webapp下都用了大量的第三方jar,其大小超过了jvm默认的大小(4m)那么就会产生此错误信息了。解决方法:
在catalina.bat的第一行增加:setjava_opts=-xms64m-xmx256m-xx:permsize=128m-xx:maxnewsize=256m-xx:maxpermsize=256m在catalina.sh的第一行增加:java_opts=-xms64m-xmx256m-xx:permsize=128m-xx:maxnewsize=256m-xx:maxpermsize=256m
3、jvm设置
堆的尺寸-xmssizeinbytes设定java堆的初始尺寸,缺省尺寸是2097152(2mb)。这个值必须是1024个字节(1kb)的倍数,且比它大。(-server选项把缺省尺寸增加到32m。)-xmnsizeinbytes为eden对象设定初始java堆的大小,缺省值为640k。(-server选项把缺省尺寸增加到2m。)-xmxsizeinbytes设定java堆的最大尺寸,缺省值为64m,(-server选项把缺省尺寸增加到128m。)最大的堆尺寸达到将近2gb(2048mb)。请注意:很多垃圾收集器的选项依赖于堆大小的设定。请在微调垃圾收集器使用内存空间的方式之前,确认是否已经正确设定了堆的尺寸。垃圾收集:内存的使用-xx:minheapfreeratio=percentageasawholenumber修改垃圾回收之后堆中可用内存的最小百分比,缺省值是40。如果垃圾回收后至少还有40%的堆内存没有被释放,则系统将增加堆的尺寸。-xx:maxheapfreeratio=percentageasawholenumber改变垃圾回收之后和堆内存缩小之前可用堆内存的最大百分比,缺省值为70。这意味着如果在垃圾回收之后还有大于70%的堆内存,则系统就会减少堆的尺寸。-xx:newsize=sizeinbytes为已分配内存的对象中的eden代设置缺省的内存尺寸。它的缺省值是640k。(-server选项把缺省尺寸增加到2m。)-xx:maxnewsize=sizeinbytes允许您改变初期对象空间的上限,新建对象所需的内存就是从这个空间中分配来的,这个选项的缺省值是640k。(-server选项把缺省尺寸增加到2m。)-xx:newratio=value改变新旧空间的尺寸比例,这个比例的缺省值是8,意思是新空间的尺寸是旧空间的1/8。-xx:survivorratio=number改变eden对象空间和残存空间的尺寸比例,这个比例的缺省值是10,意思是eden对象空间的尺寸比残存空间大survivorratio+2倍。-xx:targetsurvivorratio=percentage设定您所期望的空间提取后被使用的残存空间的百分比,缺省值是50。-xx:maxpermsize=sizeinmb长久代(permanentgeneration)的尺寸,缺省值为32(32mb)。
三、查看tomcat的jvm内存
1.tomcat6中没有设置任何默认用户,因而需要手动往tomcat6的conf文件夹下的tomcat-users.xml文件中添加用户。
如:
注:添加完需要重启tomcat6。
2.访问http://localhost:8080/manager/status,输入上面添加的用户名和密码。
3.然后在如下面的jvm下可以看到内存的使用情况。
freememory:2.50mbtotalmemory:15.53mbmaxmemory:63.56mb
四、tomcat连接数设置