我在执行以下操作时收到以下PermGen空间错误

    JasperFillManager.fillReport(reportFile.getPath(), parameters, conn);


在以下代码块中:

    compileFileName = parameters.get("reportName").toString();
    ExternalContext externalContext = FacesContext.getCurrentInstance().getExternalContext();

    ServletContext context = (ServletContext) externalContext.getContext();
    HttpServletRequest request = (HttpServletRequest) externalContext.getRequest();
    HttpServletResponse response = (HttpServletResponse) externalContext.getResponse();

    ReportConfigUtil.compileReport(context, getCompileDir(), getCompileFileName());

    File reportFile = new File(ReportConfigUtil.getJasperFilePath(context, getCompileDir(), getCompileFileName()+".jasper"));


    Class.forName(ReportsConstants.DRIVER);
    Connection conn = DriverManager.getConnection(ReportsConstants.DB_ACCESS_URL, ReportsConstants.DB_ACCESS_USER_NAME, ReportsConstants.DB_ACCESS_PASSWORD);

    parameters.put("BaseDir", reportFile.getParentFile());

    JasperPrint jasperPrint =  JasperFillManager.fillReport(reportFile.getPath(), parameters, conn);


我收到的错误如下:

    Caused by: javax.faces.el.EvaluationException: java.lang.OutOfMemoryError: PermGen space
at javax.faces.component.MethodBindingMethodExpressionAdapter.invoke(MethodBindingMethodExpressionAdapter.java:102)
at com.sun.faces.application.ActionListenerImpl.processAction(ActionListenerImpl.java:102)
... 19 more
    Caused by: java.lang.OutOfMemoryError: PermGen space
at java.lang.ClassLoader.defineClass1(Native Method)
at java.lang.ClassLoader.defineClassCond(ClassLoader.java:631)
at java.lang.ClassLoader.defineClass(ClassLoader.java:615)
at java.security.SecureClassLoader.defineClass(SecureClassLoader.java:141)


我的开发环境如下:JSF,PrimeFaces,Hibernate,JasperReports,Sybase。

您的朋友建议我如何解决该问题?

最佳答案

增加烫发空间可以使这个问题消失。添加以下参数会将其增加到128m

-XX:MaxPermSize=128m


我不确定您可以在代码中做很多事情来减少消耗的perm gen空间,因此我认为任何解决方案都与更改JVM运行时参数有关。

您也可以考虑尝试

-XX:+CMSClassUnloadingEnabled -XX:+CMSPermGenSweepingEnabled


也一样

关于java - fillReport函数期间发生PermGen空间错误,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/9779516/

10-12 00:13
查看更多