早先说过线上Resin的配置文件中要增加线程池大小、各种timeout参数(resin 4.0.15的默认配置文件肯定没有这些参数,需要另行增加)。

resin 4.0.10里,有这么一个bugthread-max的数量设置没有起作用:http://bugs.caucho.com/view.php?id=4251 ,但后面到了resin 4.0.15应该就修复了。

下面内容会给出背景介绍以及建议配置。

 

1、背景:

郑昀认为,要综合考虑resin线程池大小、“-Xmx JVM最大可用内存”、“-Xms:初始堆大小”、“-XmnYoung Generationheap size”参数互相匹配。(JVM2GC线程。第一个线程负责回收HeapYoung区。第二个线程在Heap不足时,遍历Heap,将Young 区升级为Older区。Older区的大小等于-Xmx减去-Xmn,不能将-Xms的值设的过大,因为第二个线程被迫运行会降低JVM的性能。)

来避免线上resin服务反复出现以下异常:

OutOfMemoryError Java heap space

OutOfMemoryError PermGen space

 

2Resin.xml就可以设置JDK参数:

郑昀注意到,Resin 4.0已支持把JDK参数加入resin配置文件resin.xml里。

参考resin的帮助文档

JDK arguments

Resin 4.0 has moved all JDK arguments into the resin.xml file, in the <jvm-arg> tag. Because the Resin 4.0 watchdog starts each Resin server instance, it can pass the arguments defined in the configuration file to the JVM. By moving the Java arguments to the configuration file, server configuration is easier and more maintainable.

 

3、建议规则:

1、 ServerJVM最好将-Xms-Xmx设为相同值。为了优化GC,最好让-Xmn值约等于-Xmx1/4

2、 通过增大 -XXPermSize”和“-XXMaxPermSize”这两个参数来避免出现JVM内存永久保存区域溢出引发Resin的500错误。(郑昀认为,因为线上用了spring+struts,这些框架用到大量动态classClassLoader是把这部分内存放在PermGen space里的。而JVMGC是不会清理PermGen space的。这样容易导致线上应用报告PermGen space内存溢出。)

 

4、建议resin配置:

所以,郑昀建议线上部署的Resin 4.0.15resin.xml中增加如下配置节点:

<server-default>

    <jvm-arg>-Xms1024m</jvm-arg>

    <jvm-arg>-Xmx1024m</jvm-arg>

    <jvm-arg>-Xmn256m</jvm-arg>

    <jvm-arg>-XX:PermSize=128m</jvm-arg>

<jvm-arg>-XX:MaxPermSize=256m</jvm-arg>

    <thread-max>1024</thread-max>

    <socket-timeout>30s</socket-timeout>

    <keepalive-max>512</keepalive-max>

    <keepalive-timeout>60s</keepalive-timeout>

</server-default>

 

来源:http://blog.sina.com.cn/s/blog_541086000100vxng.html