`

Tomcat部署程序启动时问题:org.apache.catalina.session.StandardManager.doLoad

阅读更多

    今天程序在Tomcat5.5.27下运行时,莫名其妙的在控制台出现以下错误:

2009/07/12-18:28:03 >> ERROR >> main >> org.apache.catalina.session.StandardManager.doLoad(StandardManager.java:373) >> 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:927)
    at org.apache.catalina.startup.HostConfig.deployDirectories(HostConfig.java:890)
    at org.apache.catalina.startup.HostConfig.deployApps(HostConfig.java:492)
    at org.apache.catalina.startup.HostConfig.start(HostConfig.java:1150)
    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/07/12-18:28:03 >> ERROR >> main >> org.apache.catalina.session.StandardManager.start(StandardManager.java:639) >> 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:927)
    at org.apache.catalina.startup.HostConfig.deployDirectories(HostConfig.java:890)
    at org.apache.catalina.startup.HostConfig.deployApps(HostConfig.java:492)
    at org.apache.catalina.startup.HostConfig.start(HostConfig.java:1150)
    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)

从网络上查找的解决方案:

(1) Tomcat\work\Catalina\localhost\project\SESSIONS.ser session未超时的情况下服务器关闭大的时候被序列化为工程名\SESSIONS.ser 启动的时候再加载进来,加载的时候报错了,把该文件删除,重新启动     补充:有时候不一定是SESSIONS.ser,我的那个下面就多了一个tldCache.ser,反正将里面以.ser结尾的都删除就是的。

(2)tomcat 启动的问题(org.apache.catalina.session.StandardManager.doLoad: IOException while loading persisted sessions) 大概是说tomcat上次关闭时还有一些活动连接,所以在重启时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_Session的持久化

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

    tomcat-servlet源码

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

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

    当Tomcat配置使用`org.apache.catalina.session.PersistentManager`作为会话管理器,并且选择`org.apache.catalina.session.FileStore`存储会话数据时,攻击者可以通过LFI漏洞读取服务器上任何以`.session`为扩展名...

    java session

    再次启动时,服务器会尝试从磁盘加载这些Session数据。如果某些对象不是可序列化的,就会抛出`NotSerializableException`异常。 2. **错误示例** ```java org.apache.catalina.session.StandardManagerdoLoad ...

    redis-tomcat-session共享包

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

    TomCat API

    TomCat API允许开发者通过编程方式动态部署和卸载应用,例如使用`org.apache.catalina.core.StandardContext`类进行上下文配置。 3. **连接器(Connector)**:TomCat通过`Connector`组件与外界进行通信,接收和...

    tomcat8 +memcached session 共享jar包

    然而,当我们的应用部署在多台服务器组成的集群时,传统的session管理机制会导致会话丢失,因为每台服务器都可能有自己的session副本,无法共享。 为了解决这个问题,我们可以利用`Memcached`作为session的存储介质...

    Session持久化

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

    Tomcat中session的管理机制

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

Global site tag (gtag.js) - Google Analytics