Weblogic启动web应用报内存溢出错误

来源:互联网 发布:淘宝如何取消超级推广 编辑:程序博客网 时间:2024/05/21 11:07

前言:
项目中使用Weblogic 11g作为应用服务器部署一个web应用,web中内嵌了一个j2ee应用,所以总体占用内存比较大,开发环境使用的tomcat都没有问题,之后向Weblogic做迁移的时候,启动就报了很多错误,诸如jar包冲突、内存溢出之类的,这里讲所遇问题以及解决方法记录下,以供遇到相同问题时参考。

一、jar包冲突

如果启动的时候报java.lang.ClassCastException类型转换错误,并且错误出现在依赖的第三方jar包,而非自身应用的话,那很有可能是出现了自带jar包与weblogic带的jar包有重复,建议删除自己工程中的此类jar包,我的项目中冲突的jar包是javax.xml和w3c相关的包,删掉含有此内容的包再启动就没问题了,weblogic自带了解析xml的包,不需要担心。
1.配置weblogic.xml文件
weblogic.xml是必须要的,放在WEB-INF下和web.xml同级,可以尝试在里面加入下面的属性

<container-descriptor>   <prefer-web-inf-classes>true</prefer-web-inf-classes> </container-descriptor>

从节点名称上也能比较清楚知道该设置的含义,优先使用Web应用里加载的类。但实际上,即便如此配了,上述冲突的问题依然没有解决,因此只能进行删除
2.删除冲突jar包
这次出现的问题是因为javax.xml和w3c中xml的包冲突导致的,删除后就没有问题了,是否还有其他jar包冲突,待遇到后会及时补充,附含有javax.xml的包:
jaxrpc.jar
stax.jar
wstx.jar
xml-apis.jar

二、内存溢出

报java.lang.OutOfMemoryError:PermGen space
我们都知道java启动的时候需要输入启动参数,包括-Xms(内存初始分配值),-Mmx(内存最大允许分配的堆值),-XX:PermSize(初始分配PermGen区域值),-XX:MaxPermSize(PermGen区域的最大值)。
这其中PermGen space的全称是Permanent Generation space,是指内存的永久保存区域,这块内存主要是被JVM存放Class和Meta信息的,Class在被Loader时就会被放到PermGen space中,它和存放类实例(Instance)的Heap区域不同,GC(Garbage Collection)不会在主程序运行期对PermGen space进行清理,所以如果你的应用中有很多CLASS的话,就很可能出现PermGen space错误,这种错误常见在web服务器对JSP进行pre compile的时候。如果你的WEB APP下都用了大量的第三方jar, 其大小超过了jvm默认的大小(4M)那么就会产生此错误信息了。
1.所以我们需要修改weblogic启动domain时的内存参数:
在文件/bea/user_projects/domains/{domain_name}/bin/setDomainEnv.sh中
根据使用JVM的厂商,修改对应分支的参数,下面是SUN的情况

if [ "${JAVA_VENDOR}" = "Sun" ] ; then        MEM_ARGS="${MEM_ARGS} ${MEM_DEV_ARGS} -XX:MaxPermSize=128m"        export MEM_ARGSfi

中MaxPermSize调大,再验证问题是否还存在。
2.若是问题还在,如果修改分支没错的话,再尝试修改另一个文件
修改weblogic安装目录下wlserver\common\bin\commEnv.cmd,找到set MEM_ARGS=-Xms32m -Xmx200m -XX:MaxPermSize=128m,修改成set MEM_ARGS=-Xms256m -Xmx512m -XX:MaxPermSize=256m,可根据机器配置调整。其中有针对oracle自己jvm和sun jvm的配置,我使用的是sum的jvm所以只修改了“:sun”下面的MEM_ARGS。

1 0
原创粉丝点击