Tomcat Embedded启动错误

时间:2016-08-01 12:55:02

标签: java spring tomcat spring-boot

我正在开发一个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

1 个答案:

答案 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文件,错误神奇地消失了。