JBoss EAP 6.1中的HTTP会话复制

时间:2013-09-16 15:31:28

标签: jboss7.x httpsession infinispan jboss-eap-6

我正在尝试将我的JSF Web应用程序部署在具有两个节点的“域”集群中。

我无法在节点之间复制HTTP会话。

我已配置 web.xml

<?xml version="1.0" encoding="UTF-8"?>
<web-app version="3.0" xmlns="http://java.sun.com/xml/ns/javaee"
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd">

    <session-config>
        <session-timeout>30</session-timeout>
    <tracking-mode>URL</tracking-mode>
    </session-config>

  <distributable></distributable>

</web-app>

jboss-web.xml

<?xml version="1.0" encoding="UTF-8"?>
<jboss-web>
    <context-root>thumbzup-admin</context-root>

    <!--replication-config>
      <replication-trigger>SET_AND_NON_PRIMITIVE_GET</replication-trigger>
      <replication-granularity>SESSION</replication-granularity>
    </replication-config-->
  <replication-config>
    <cache-name>custom-session-cache</cache-name>
    <replication-trigger>SET</replication-trigger>
    <replication-granularity>ATTRIBUTE</replication-granularity>
    <!--replication-field-batch-mode>true</replication-field-batch-mode-->
    <use-jk>false</use-jk>
    <max-unreplicated-interval>30</max-unreplicated-interval>
    <snapshot-mode>INSTANT</snapshot-mode>
    <snapshot-interval>1000</snapshot-interval>
    <replication-mode>SYNCHRONOUS</replication-mode>
    <!--session-notification-policy>com.example.CustomSessionNotificationPolicy</session-notification-policy-->
  </replication-config>
</jboss-web>

domain.xml中的Infinispan缓存容器;

<cache-container name="web" aliases="standard-session-cache" default-cache="repl" module="org.jboss.as.clustering.web.infinispan">
                    <transport lock-timeout="60000"/>
                    <replicated-cache name="repl" mode="ASYNC" batching="true">
                        <file-store/>
                    </replicated-cache>
                    <replicated-cache name="sso" mode="SYNC" batching="true"/>
                    <distributed-cache name="dist" l1-lifespan="0" mode="ASYNC" batching="true">
                        <file-store/>
                    </distributed-cache>
                </cache-container>

但是在NODE2上使用相同的SESSIONID时,我无法检索在NODE1上创建的会话。

有什么建议吗?

1 个答案:

答案 0 :(得分:2)

这个名字     &#34;自定义会话高速缓存&#34; 您在jboss-web.xml中定义的内容似乎与domain.xml中的任何缓存都不匹配。删除&#34; 缓存名称&#34;属性完全使用&#34; default-cache&#34;的值&#34; web&#34;的财产容器或添加具有该名称的缓存条目