在JSP编译期间'tmpFile.renameTo(classFile)失败的原因'

时间:2010-09-10 21:52:38

标签: jsp jboss tomcat5.5

最近,我开始在JBOss 4.0.5 JSP应用程序中遇到奇怪的行为。 JSP编译在第一次(第二次,第三次,...)尝试失败,但异常:

17:24:29,909 ERROR [[jsp]] Servlet.service() for servlet jsp threw exception
java.io.IOException: tmpFile.renameTo(classFile) failed
        at org.apache.jasper.compiler.SmapUtil$SDEInstaller.install(SmapUtil.java:245)
        at org.apache.jasper.compiler.SmapUtil.installSmap(SmapUtil.java:164)
        at org.apache.jasper.compiler.JDTCompiler.generateClass(JDTCompiler.java:429)
        at org.apache.jasper.compiler.Compiler.compile(Compiler.java:297)
        at org.apache.jasper.compiler.Compiler.compile(Compiler.java:276)
        at org.apache.jasper.compiler.Compiler.compile(Compiler.java:264)
        at org.apache.jasper.JspCompilationContext.compile(JspCompilationContext.java:563)
        at org.apache.jasper.servlet.JspServletWrapper.service(JspServletWrapper.java:305)
        at org.apache.jasper.servlet.JspServlet.serviceJspFile(JspServlet.java:314)
        at org.apache.jasper.servlet.JspServlet.service(JspServlet.java:264)

经过几次重试(少数是0到7),页面最终被编译并呈现正常。

平台是Windows 7-Pro 64位,Java版本是

c:\ATG\ATG2007.1>java -version
java version "1.5.0_21"
Java(TM) 2 Runtime Environment, Standard Edition (build 1.5.0_21-b01)
Java HotSpot(TM) Client VM (build 1.5.0_21-b01, mixed mode)

JBoss版本:

16:49:51,384 INFO  [Server] Release ID: JBoss [Zion] 4.0.5.GA (build: CVSTag=Branch_4_0 date=200610162339)

Tomcat版本是5.5(JBoss附带的版本)。

感谢。

3 个答案:

答案 0 :(得分:8)

快进四年到2014年.Tomcat 8,Java 8,Windows 8,同样的错误。经过半天的挫折之后,事实证明这是由我的防病毒软件造成的,在我的案例中是McAfee。我走极端,卸下了整件事。但是可能有一些设置可以将Tomcat目录排除在实时扫描之外。

答案 1 :(得分:5)

抛出IOException的文件夹实际上是只读的,在将其更改为可写入后,工作正常。

答案 2 :(得分:4)

这与Tomcat 5.5 bug 38713有关。它似乎在Tomcat 5.5.25开始修复。