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
我终于找到了解决我的问题。
读前面回答这个问题: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
文件,该错误神奇消失。
高兴它帮助:),但你仍然发现任何线索,为什么它发生在第一个地方?你是否手动杀死弹簧启动应用程序?不让上下文正确关闭? – AntJavaDev
@AntJavaDev是的,可能问题是由于错误的应用程序停止引起的。非常感谢你! – davioooh
该文件的正确名称是“session.ser”而不是“sessions.ser”。它为我工作。谢谢。 – d9daniel
以及错误清楚地表明,在重新启动或关闭您的春天的应用程序,某些某些文件被损坏。如果你想使用持久性会话,你必须使用持久性管理器来正确配置它,在[链接]中提到(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