我正在开发一个Spring Boot(v1.3.3.RELEASE)项目。包含的Tomcat Embedded版本是8.0.32。
我收到此错误:
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中建议的解决方案,但在我的情况下,我找不到通往" Clean Tomcat Work Directory"或者只是为了清理我的应用程序。
我该如何解决这个问题?在哪里可以找到 Tomcat Embedded 版本的工作文件夹?
注意我使用Eclipse作为IDE
答案 0 :(得分:7)
我终于找到了解决问题的方法。
阅读这个问题的答案: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 Embedded存储缓存会话的位置(在Windows上):
C:\Users\<my-user>\AppData\Local\Temp\<random-id>\servlet-sessions\
我删除了此文件夹中的SESSIONS.ser
文件,错误神奇地消失了。