redis异常解决:attempted to load session[xxx] which has been created but not yet serialized.

文章详细介绍了在使用Redis做Tomcat session共享时遇到的Race condition encountered异常,并通过分析发现原因是客户端请求时传入了多个JSESSIONID。通过清除cookie并重新请求解决了问题。同时探讨了为何会出现多个JSESSIONID的情况,有待进一步研究。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

使用redis做了tomcat的session共享,又一次访问session时出现下面的异常:

java.lang.IllegalStateException: Race condition encountered: attempted to load session[23DF9FE58DAF67B589642E88254593DA] which has been created but not yet serialized.
at com.radiadesign.catalina.session.RedisSessionManager.loadSessionFromRedis(RedisSessionManager.java:399)
at com.radiadesign.catalina.session.RedisSessionManager.findSession(RedisSessionManager.java:325)
at org.apache.catalina.connector.Request.isRequestedSessionIdValid(Request.java:2385)
at org.apache.catalina.connector.CoyoteAdapter.parseSessionCookiesId(CoyoteAdapter.java:1033)
at org.apache.catalina.connector.CoyoteAdapter.postParseRequest(CoyoteAdapter.java:764)
at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:416)
at org.apache.coyote.http11.AbstractHttp11Processor.process(AbstractHttp11Processor.java:1070)
at org.apache.coyote.AbstractProtocol$AbstractConnectionHandler.process(AbstractProtocol.java:611)
at org.apache.tomcat.util.net.AprEndpoint$SocketProcessor.doRun(AprEndpoint.java:2466)
at org.apache.tomcat.util.net.AprEndpoint$SocketProcessor.run(AprEndpoint.java:2455)
at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1145)
at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:615)
at org.apache.tomcat.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:61)
at java.lang.Thread.run(Thread.java:745)
九月 15, 2015 9:35:28 上午 org.apache.coyote.http11.AbstractHttp11Processor process

解决方法

后来在网上看到说是客户端请求时传了多个JSESSIONID的原因,打开浏览器监控一看,果然是这样,如图,于是清除cookie,再次请求,问题解决。

至于为何会出现多个JSESSIONID的问题,还有待研究。


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值