Tomcat嵌入式启动时出错

问题描述:

我正在开发Spring Boot(v1.3.3.RELEASE)项目。包含的Tomcat Embedded版本是8.0.32。Tomcat嵌入式启动时出错

我得到这个错误:

2016-08-01 14:51:23.354 ERROR 6704 --- [ost-startStop-1] o.a.catalina.session.StandardManager  : Exception loading sessions from persistent storage 

java.io.EOFException: null 
    at java.io.ObjectInputStream$PeekInputStream.readFully(ObjectInputStream.java:2335) 
    ... 

我了解在这个问题上同样的错误:exception loading sessions from persistent storage但我无法找到解决我的问题。

我试图应用在aswers中建议的解决方案,但在我的情况下,我找不到“清洁Tomcat工作目录”或只是为了清洁部署我的应用程序。

我该如何解决这个问题?我在哪里可以找到工作文件夹Tomcat Embedded版本?

注意我使用Eclipse作为IDE

+0

以及错误清楚地表明,在重新启动或关闭您的春天的应用程序,某些某些文件被损坏。如果你想使用持久性会话,你必须使用持久性管理器来正确配置它,在[链接]中提到(https://tomcat.apache.org/tomcat-5.5-doc/config/manager.html) (对于Tomcat 5.5),否则解决方案是完全禁用它与此[答案](http://stackoverflow.com/questions/27130157/how-to-disable-tomact-session-persistence-in-spring-boot-通过管理器路径名) – AntJavaDev

我终于找到了解决我的问题。

读前面回答这个问题:How to disable Tomact session persistence in Spring Boot via Manager pathname?(由AntJavaDev建议)我配置这个bean:

@Bean 
public EmbeddedServletContainerFactory servletContainer() { 
    TomcatEmbeddedServletContainerFactory tomcat = new TomcatEmbeddedServletContainerFactory(); 
    tomcat.addContextCustomizers(new TomcatContextCustomizer() { 

     @Override 
     public void customize(Context context) { 
      if (context.getManager() instanceof StandardManager) { 
       // print local path name 
       System.out.println(((StandardManager) context.getManager()).getPathname()); 
      } 
     } 
    }); 
    return tomcat; 
} 

这样,我发现那里缓存中的会话存储为Tomcat嵌入式(Windows上):

C:\Users\<my-user>\AppData\Local\Temp\<random-id>\servlet-sessions\ 

我删除了这个文件夹中的SESSIONS.ser文件,该错误神奇消失。

+0

高兴它帮助:),但你仍然发现任何线索,为什么它发生在第一个地方?你是否手动杀死弹簧启动应用程序?不让上下文正确关闭? – AntJavaDev

+0

@AntJavaDev是的,可能问题是由于错误的应用程序停止引起的。非常感谢你! – davioooh

+0

该文件的正确名称是“session.ser”而不是“sessions.ser”。它为我工作。谢谢。 – d9daniel