tomcat启动时出现异常Exception loading sessions from persistent storage分析: session未超时的情况下,服务器关闭的时候会被序列化为工程名\

本文介绍了解决Tomcat启动时出现的Java.io.EOFException问题的方法,该异常通常发生在尝试加载上次非正常关闭时遗留的session数据时。通过删除SESSIONS.ser文件可以解决此问题。
Exception loading sessions from persistent storage 
Java.io.EOFException 
at java.io.ObjectInputStream$PeekInputStream.readFully(ObjectInputStream.java:2228) 
at java.io.ObjectInputStream$BlockDataInputStream.readShort(ObjectInputStream.java:2694) 
at java.io.ObjectInputStream.readStreamHeader(ObjectInputStream.java:761) 
at java.io.ObjectInputStream.<init>(ObjectInputStream.java:277) 
at org.apache.catalina.util.CustomObjectInputStream.<init>(CustomObjectInputStream.java:56) 
at org.apache.catalina.session.StandardManager.doLoad(StandardManager.java:384) 
at org.apache.catalina.session.StandardManager.load(StandardManager.java:343) 
at org.apache.catalina.session.StandardManager.start(StandardManager.java:657) 
at org.apache.catalina.core.ContainerBase.setManager(ContainerBase.java:499) 
at org.apache.catalina.startup.ContextConfig.managerConfig(ContextConfig.java:315) 
at org.apache.catalina.startup.ContextConfig.start(ContextConfig.java:635) 
at org.apache.catalina.startup.ContextConfig.lifecycleEvent(ContextConfig.java:216) 
at org.apache.catalina.util.LifecycleSupport.fireLifecycleEvent(LifecycleSupport.java:119) 
at org.apache.catalina.core.StandardContext.start(StandardContext.java:4290) 

at org.apache.catalina.core.ContainerBase.addChildInternal(ContainerBase.java:823) 

~~~~~~~~~~~~~~~~~


分析: session未超时的情况下,服务器关闭的时候会被序列化为工程名\SESSIONS.ser,tomcat 启动的时候再加载进来,EOFException表示tomcat上次关闭时还有一些活动连接,所以在重启时tomcat尝试去恢复这些session,但是在输入过程中意外地到达文件尾或流尾的信号,导致从session中获取数据失败。异常是tomcat本身的问题,由于tomcat上次非正常关闭时有一些活动session被持 久化(表现为一些临时文件),在重启时,tomcat尝试去恢复这些session的持久化数据但又读取失败造成的。此异常不影响系统的使用。

解决办法:将 tomcat_home\work\Catalina\localhost\『工程名』\SESSIONS.ser删除。如果正常关闭服务端,该文件是自 动删除的。考虑到每个人的tomat的工作目录不同,建议在“搜索”功能中找到你的SESSIONS.ser文件,而且只需要删 除..\yourProjectName\下的SESSIONS.ser即可。 

最简单的办法是work下的全部删除,然后重启tomcat。


下面是有关tomcat 的work目录的知识:

1    用tomcat作web服务器的时候,部署的程序在webApps下,这些程序都是编译后的程序(发布到tomcat的项目里含的类,会被编译成.class后才发布过来,源文件没有发布过来,但这里的jsp没有经编译的)。tomcat有一个work目录,里面存放了页面的缓存,访问的jsp都会编译(从work里进入Catalina后的如localhost站点文件夹下的项目,我们可以看到那些jsp 页面会被编译成应该是servlet文件,下次再来访问时,就直接运行servlet类就可以向客户端反应响应页面了,所以有的博客说第一次访问时会比较 慢,是因为新发布上去的页面在第一个人访问时,会先编译成servlet文件,所以慢了,一旦编译好,那么除非jsp页面修改,不然下次访问直接运行 servlet就可以响应用户,所以快),编译后的文件都会存储在work目录下。而tomcat显示的目录,都会从这个缓存里找编译后的jsp对应的class文件。所以当清空了work目录后,该过程将会从新来过。     
    有的时候会遇到一个问题,就是修改后的页面在tomcat运行的时候显示不了修改后的痕迹。这个时候删除work目录下对应的项目文件夹,重新启动tomcat就可以了。

2   在tomcat的conf配置文件夹下的server.xml文件里配置了Host name后,就会在conf下的Catalina文件夹和work下的Catalina文件下建立站点名称的文件夹,项目每次发布都会放入来,也会记录到conf下的Catalina文件夹的配置文件里去。


from:http://getspring.blog.163.com/blog/static/115300609201073010022281/


在登录成功后,`sessionID` 通常通过 HTTP 响应头中的 `Set-Cookie` 字段传回前端。服务器会在用户登录成功时创建或获取当前用户的 `HttpSession` 对象,并生成一个唯一的 `sessionID`。该 `sessionID` 被封装在 Cookie 中,并通过响应头自动发送给客户端。 例如,在 Spring Boot 应用中,当用户登录成功时,服务器端会处理如下逻辑: ```java @PostMapping("/login") public ResponseEntity<String> login(@RequestParam String username, @RequestParam String password, HttpSession session) { if (isValidUser(username, password)) { session.setAttribute("user", new User(username)); return ResponseEntity.ok("Login successful"); } else { return ResponseEntity.status(HttpStatus.UNAUTHORIZED).body("Invalid credentials"); } } ``` 在这个过程中,服务器会在响应头中添加类似以下内容: ``` Set-Cookie: JSESSIONID=abc123xyz; Path=/; HttpOnly ``` 前端(如浏览器)接收到该响应后,会存储该 Cookie,并在后续的请求中自动携带此 Cookie 到服务器,确保会话的连续性[^3]。 关于 `sessionID` 是否由服务器响应时自动添加的问题,答案是肯定的。`sessionID` 是服务器在响应时自动添加的,且这个过程是由 Servlet 容器(如 Tomcat)负责处理的。Tomcat 在用户首次访问服务器时会生成一个唯一的 `JSESSIONID`,并通过 `Set-Cookie` 头部将该 ID 发送到客户端。如果客户端支持 Cookie,则会保存该值,并在后续请求中将其附加到请求头中,以便服务器识别会话[^3]。 此外,Tomcat 还提供了对 Session 的持久化和集群支持。例如,默认情况下Tomcat 在正常关闭时会将活跃的 Session 序列化到本地文件“SESSIONS.ser”中,重启时可以恢复这些 Session 数据[^1]。对于分布式部署,Tomcat 支持使用 `DeltaManager` 实现 Session 的跨节点复制,从而保证多个服务器实例之间的会话一致性[^2]。 ###
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值