- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在从事的 Grails 项目已将 war 部署到启用了 session 复制的多个 Tomcat。
除了开始在所有 g:form 实体中使用 useToken 外,我们最近对 session 做了一些小改动。 (可能还有其他人,但初步查看所有最近提交的代码找不到任何相关内容。)
我知道下面的错误与 session 对象不可序列化有关,但我不确定从哪里开始查找。
有人遇到过 Grails 中的以下错误吗?
会不会和表单中的useToken有关?
这是 g:forms 中 useToken 的已知限制 - 它们不支持序列化吗?
或者,我如何找到 session 中的所有对象以查看是哪个对象导致了此错误?
org.apache.catalina.ha.session.DeltaManager.requestCompleted Unable to serialize delta request for sessionid [6F6A26B3FF57A901F5D868FB68CA4A6F]
java.io.NotSerializableException: groovy.lang.MapWithDefault
at java.io.ObjectOutputStream.writeObject0(ObjectOutputStream.java:1183)
at java.io.ObjectOutputStream.defaultWriteFields(ObjectOutputStream.java:1547)
at java.io.ObjectOutputStream.writeSerialData(ObjectOutputStream.java:1508)
at java.io.ObjectOutputStream.writeOrdinaryObject(ObjectOutputStream.java:1431)
at java.io.ObjectOutputStream.writeObject0(ObjectOutputStream.java:1177)
at java.io.ObjectOutputStream.writeObject(ObjectOutputStream.java:347)
at org.apache.catalina.ha.session.DeltaRequest$AttributeInfo.writeExternal(DeltaRequest.java:384)
at org.apache.catalina.ha.session.DeltaRequest.writeExternal(DeltaRequest.java:277)
at org.apache.catalina.ha.session.DeltaRequest.serialize(DeltaRequest.java:291)
at org.apache.catalina.ha.session.DeltaManager.serializeDeltaRequest(DeltaManager.java:617)
at org.apache.catalina.ha.session.DeltaManager.requestCompleted(DeltaManager.java:1000)
at org.apache.catalina.ha.session.DeltaManager.requestCompleted(DeltaManager.java:965)
at org.apache.catalina.ha.tcp.ReplicationValve.send(ReplicationValve.java:525)
at org.apache.catalina.ha.tcp.ReplicationValve.sendMessage(ReplicationValve.java:513)
at org.apache.catalina.ha.tcp.ReplicationValve.sendSessionReplicationMessage(ReplicationValve.java:495)
at org.apache.catalina.ha.tcp.ReplicationValve.sendReplicationMessage(ReplicationValve.java:406)
at org.apache.catalina.ha.tcp.ReplicationValve.invoke(ReplicationValve.java:329)
at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:537)
at org.apache.coyote.http11.AbstractHttp11Processor.process(AbstractHttp11Processor.java:1085)
at org.apache.coyote.AbstractProtocol$AbstractConnectionHandler.process(AbstractProtocol.java:658)
at org.apache.coyote.http11.Http11NioProtocol$Http11ConnectionHandler.process(Http11NioProtocol.java:222)
at org.apache.tomcat.util.net.NioEndpoint$SocketProcessor.doRun(NioEndpoint.java:1556)
at org.apache.tomcat.util.net.NioEndpoint$SocketProcessor.run(NioEndpoint.java:1513)
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)
最佳答案
找到答案:这是 Grails 2.2.1 的一个已知问题。
参见 https://jira.grails.org/browse/GRAILS-9923
因此,从本质上讲,如果您使用 Grails 2.2.1 并在集群中启用 session 复制,并且使用 token ,它将中断 session 复制。
关于session - Grails Tomcat 无法序列化 sessionid : groovy. lang.MapWithDefault 的增量请求,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33002996/
我正在编写一些 jUnit 测试,其中我需要断言 groovy.lang.MapWithDefault 和 java.util.HashMap 之间的相等性: assertEquals(lMapWit
我正在从事的 Grails 项目已将 war 部署到启用了 session 复制的多个 Tomcat。 除了开始在所有 g:form 实体中使用 useToken 外,我们最近对 session 做了
我是一名优秀的程序员,十分优秀!