`
pcial
  • 浏览: 71578 次
  • 性别: Icon_minigender_1
  • 来自: 广州
社区版块
存档分类
最新评论

关于org.apache.catalina.session.StandardManager doLoad错误的解决

    博客分类:
  • JAVA
阅读更多

2009-7-28 14:46:11 org.apache.catalina.session.StandardManager doLoad
在开发项目的时候,偶尔遇到了如下问题,在启动tomcat时抛出下列异常

严重: IOException while loading persisted sessions: java.io.EOFException
java.io.EOFException
 at java.io.ObjectInputStream$PeekInputStream.readFully(ObjectInputStream.java:2232)
 at java.io.ObjectInputStream$BlockDataInputStream.readShort(ObjectInputStream.java:2698)
 at java.io.ObjectInputStream.readStreamHeader(ObjectInputStream.java:750)
 at java.io.ObjectInputStream.<init>(ObjectInputStream.java:268)
 at org.apache.catalina.util.CustomObjectInputStream.<init>(CustomObjectInputStream.java:58)
 at org.apache.catalina.session.StandardManager.doLoad(StandardManager.java:362)
 at org.apache.catalina.session.StandardManager.load(StandardManager.java:321)
 at org.apache.catalina.session.StandardManager.start(StandardManager.java:637)
 at org.apache.catalina.core.ContainerBase.setManager(ContainerBase.java:432)
 at org.apache.catalina.core.StandardContext.start(StandardContext.java:4160)
 at org.apache.catalina.core.ContainerBase.addChildInternal(ContainerBase.java:760)
 at org.apache.catalina.core.ContainerBase.addChild(ContainerBase.java:740)
 at org.apache.catalina.core.StandardHost.addChild(StandardHost.java:544)
 at org.apache.catalina.startup.HostConfig.deployDirectory(HostConfig.java:920)
 at org.apache.catalina.startup.HostConfig.deployDirectories(HostConfig.java:883)
 at org.apache.catalina.startup.HostConfig.deployApps(HostConfig.java:492)
 at org.apache.catalina.startup.HostConfig.start(HostConfig.java:1138)
 at org.apache.catalina.startup.HostConfig.lifecycleEvent(HostConfig.java:311)
 at org.apache.catalina.util.LifecycleSupport.fireLifecycleEvent(LifecycleSupport.java:120)
 at org.apache.catalina.core.ContainerBase.start(ContainerBase.java:1022)
 at org.apache.catalina.core.StandardHost.start(StandardHost.java:736)
 at org.apache.catalina.core.ContainerBase.start(ContainerBase.java:1014)
 at org.apache.catalina.core.StandardEngine.start(StandardEngine.java:443)
 at org.apache.catalina.core.StandardService.start(StandardService.java:448)
 at org.apache.catalina.core.StandardServer.start(StandardServer.java:700)
 at org.apache.catalina.startup.Catalina.start(Catalina.java:552)
 at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
 at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
 at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
 at java.lang.reflect.Method.invoke(Method.java:585)
 at org.apache.catalina.startup.Bootstrap.start(Bootstrap.java:295)
 at org.apache.catalina.startup.Bootstrap.main(Bootstrap.java:433)
2009-7-28 14:46:11 org.apache.catalina.session.StandardManager start
严重: Exception loading sessions from persistent storage
java.io.EOFException
 at java.io.ObjectInputStream$PeekInputStream.readFully(ObjectInputStream.java:2232)
 at java.io.ObjectInputStream$BlockDataInputStream.readShort(ObjectInputStream.java:2698)
 at java.io.ObjectInputStream.readStreamHeader(ObjectInputStream.java:750)
 at java.io.ObjectInputStream.<init>(ObjectInputStream.java:268)
 at org.apache.catalina.util.CustomObjectInputStream.<init>(CustomObjectInputStream.java:58)
 at org.apache.catalina.session.StandardManager.doLoad(StandardManager.java:362)
 at org.apache.catalina.session.StandardManager.load(StandardManager.java:321)
 at org.apache.catalina.session.StandardManager.start(StandardManager.java:637)
 at org.apache.catalina.core.ContainerBase.setManager(ContainerBase.java:432)
 at org.apache.catalina.core.StandardContext.start(StandardContext.java:4160)
 at org.apache.catalina.core.ContainerBase.addChildInternal(ContainerBase.java:760)
 at org.apache.catalina.core.ContainerBase.addChild(ContainerBase.java:740)
 at org.apache.catalina.core.StandardHost.addChild(StandardHost.java:544)
 at org.apache.catalina.startup.HostConfig.deployDirectory(HostConfig.java:920)
 at org.apache.catalina.startup.HostConfig.deployDirectories(HostConfig.java:883)
 at org.apache.catalina.startup.HostConfig.deployApps(HostConfig.java:492)
 at org.apache.catalina.startup.HostConfig.start(HostConfig.java:1138)
 at org.apache.catalina.startup.HostConfig.lifecycleEvent(HostConfig.java:311)
 at org.apache.catalina.util.LifecycleSupport.fireLifecycleEvent(LifecycleSupport.java:120)
 at org.apache.catalina.core.ContainerBase.start(ContainerBase.java:1022)
 at org.apache.catalina.core.StandardHost.start(StandardHost.java:736)
 at org.apache.catalina.core.ContainerBase.start(ContainerBase.java:1014)
 at org.apache.catalina.core.StandardEngine.start(StandardEngine.java:443)
 at org.apache.catalina.core.StandardService.start(StandardService.java:448)
 at org.apache.catalina.core.StandardServer.start(StandardServer.java:700)
 at org.apache.catalina.startup.Catalina.start(Catalina.java:552)
 at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
 at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
 at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
 at java.lang.reflect.Method.invoke(Method.java:585)
 at org.apache.catalina.startup.Bootstrap.start(Bootstrap.java:295)
 at org.apache.catalina.startup.Bootstrap.main(Bootstrap.java:433)
2009-7-28 14:46:32 org.apache.coyote.http11.Http11BaseProtocol start

该异常是由于关闭服务器时tomcat上次关闭时还有一些活动连接,Session未超时,将Session保存在磁盘上,在启动时又重新加载,所以在重启时tomcat尝试去恢复这些session造成的

解决方法:tomcat的work目录下面的东西删一遍。

分享到:
评论

相关推荐

    集群 Tomcat 6.x 和 Tomcat 7.x,使用 redis 存储会话.zip

    集群 Tomcat 6.x 和 Tomcat 7.x,使用 redis 存储会话实现RedisManager继承org.apache.catalina.session.StandardManager,RedisSession继承org.apache.catalina.session.StandardSession。安装步骤:1. 复制:wjw-...

    tomcat-servlet源码

    `org.apache.catalina.session.ManagerBase`和它的子类如`PersistentManager`、`StandardManager`处理Session的创建、更新、过期和持久化。 8. **线程模型** Tomcat使用基于NIO的Acceptor线程模型来处理并发请求,...

    [Timeline Sec] - CVE-2020-9484:Tomcat Session 反序列化复现1

    CVE-2020-9484的根源在于错误配置和`org.apache.catalina.session.FileStore`组件中的本地文件包含(LFI)以及反序列化问题。当Tomcat配置使用`org.apache.catalina.session.PersistentManager`作为会话管理器,并且...

    Tomcat_Session的持久化

    Tomcat 实现持久 Session Store 的接口为 org.apache.Catalina.store,目前提供了两个实现这一接口的类:org.apache.Catalina.FileStore 和 org.apache.Catalina.JDBCStore。 FileStore 将 HttpSession 对象保存在...

    java session

    &lt;Manager className="org.apache.catalina.session.PersistentManager" saveOnRestart="false"&gt; &lt;Store className="org.apache.catalina.session.FileStore" /&gt; ``` 这样配置可以避免在服务器关闭时保存...

    Session持久化

    &lt;Store className="org.apache.catalina.session.FileStore" directory="/path/to/store/directory"/&gt; ``` 在上面的例子中,`/path/to/store/directory`是你自定义的存储目录,可以更改此路径以适应实际部署...

    redis-tomcat-session共享包

    你需要创建一个自定义的`Manager`类,继承自`org.apache.catalina.session.StandardManager`,并在其中实现与Redis的交互逻辑。这通常包括使用Jedis API来存储和检索session数据。 4. **配置Context**:在Tomcat的`...

    TomCat API

    TomCat API提供了`org.apache.catalina`包,其中包含一系列接口和类,如`Container`、`Engine`、`Host`和`Context`,它们代表了不同层次的容器结构,帮助开发者管理Servlet的生命周期。 2. **部署与配置**:在...

    tomcat8 +memcached session 共享jar包

    2. `Tomcat`的session管理器实现:如`MemcachedSessionManager`,它替代了默认的`StandardManager`,负责将session操作转发给`Memcached`服务器。 3. 可能还包括配置示例和依赖的jar包,帮助用户快速配置和启动...

    Tomcat中session的管理机制

    实际上,`HttpServletRequest`是一个接口,实际实现是`RequestFacade`,它包装了`org.apache.catalina.connector.Request`。`RequestFacade`通过`getSession`方法调用底层的`Request`对象的`getSession`方法来获取...

Global site tag (gtag.js) - Google Analytics