Tomcat Embedded启动时出错

dav*_*ooh 6 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)
    ...
Run Code Online (Sandbox Code Playgroud)

我在这个问题上读到了同样的错误:从持久存储加载会话异常,但我无法找到解决问题的方法.

我尝试应用aswers中建议的解决方案,但在我的情况下,我找不到"清理Tomcat工作目录"的方法或只是为了清理我的应用程序部署.

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

注意我使用Eclipse作为IDE

dav*_*ooh 7

我终于找到了我的问题的解决方案.

阅读这个问题的答案:如何通过管理员路径名禁用Spring Boot中的Tomact会话持久性?(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;
}
Run Code Online (Sandbox Code Playgroud)

这样我就发现了为Tomcat Embedded存储缓存会话的位置(在Windows上):

C:\Users\<my-user>\AppData\Local\Temp\<random-id>\servlet-sessions\
Run Code Online (Sandbox Code Playgroud)

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