2017-03-01 96 views
0

我试图在JBoss EAP 7(或Wildfly 10)服务器上创建一个JDBC支持的Infinispan缓存。我在standalone-full.xmlcache-container定义是这样的:JDBC支持的JBoss EAP/Wildfly上的Infinispan缓存

<cache-container name="SearchCacheContainer" default-cache="SearchCache" module="org.infinispan.cachestore.jdbc"> 
       <local-cache name="SearchCache"> 
        <expiration max-idle="60000" interval="6000"/> 
        <transaction mode="FULL_XA"/>     
        <string-keyed-jdbc-store data-source="java:jboss/datasources/InfinispanCacheDS" preload="true" passivation="false" purge="false"> 
         <property name="databaseType"> 
          postgres 
         </property> 
         <property name="createTableOnStart"> 
          true 
         </property> 
         <string-keyed-table prefix="str_"> 
          <id-column name="id" type="VARCHAR2(200)"/> 
          <data-column name="datum" type="BLOB"/> 
          <timestamp-column name="version" type="NUMBER"/> 
         </string-keyed-table> 
        </string-keyed-jdbc-store> 
       </local-cache> 
      </cache-container> 

我也宣布我的服务器这样必要的JDBC数据源:

<datasource jndi-name="java:jboss/datasources/InfinispanCacheDS" pool-name="InfinispanCacheDS" enabled="true" use-java-context="true"> 
       <connection-url>jdbc:postgresql://localhost:5432/db_infinispan_cache</connection-url> 
       <driver>postgresql-jdbc4</driver> 
       <pool> 
        <min-pool-size>10</min-pool-size> 
        <max-pool-size>20</max-pool-size> 
        <prefill>true</prefill> 
        <flush-strategy>IdleConnections</flush-strategy> 
       </pool> 
       <security> 
        <user-name>infinispan_cache</user-name> 
        <password>mypasswordhere</password> 
       </security> 
       <validation> 
        <valid-connection-checker class-name="org.jboss.jca.adapters.jdbc.extensions.postgres.PostgreSQLValidConnectionChecker"/> 
        <validate-on-match>true</validate-on-match> 
        <exception-sorter class-name="org.jboss.jca.adapters.jdbc.extensions.postgres.PostgreSQLExceptionSorter"/> 
       </validation> 
       <statement> 
        <track-statements>true</track-statements> 
       </statement> 
      </datasource> 

然而,当我尝试启动我的JBoss服务器,我见以下错误和服务器无法启动:

14:02:09,692 ERROR [org.jboss.as.controller] (Controller Boot Thread) WFLYCTL0362: Capabilities required by resource '/subsystem=infinispan/cache-container=SearchCacheContainer/local-cache=SearchCache/store=string-jdbc' are not available: 
    org.wildfly.data-source.java:jboss/datasources/InfinispanCacheDS; There are no known registration points which can provide this capability. 

任何人都可以解释我在这里做错了什么吗?关于这个特殊功能的文档看起来很简单,所以我确定有一些我错过了,但不知道是什么。谢谢!

+1

尽量设置'数据源= “InfinispanCacheDS”' –

+0

看起来就是这样!尽管它不是在启动时创建表,并且它抱怨createTableOnStart属性。任何想法是什么使用正确的标志是? – Shadowman

+0

在xsd for infinispan 8.x(包含在wildfly 10中)https://docs.jboss.org/infinispan/schemas/infinispan-cachestore-jdbc-config-8.0.xsd属性createTableOnStart对于缓存存储不存在元素,表元素有createOnStart(create-on-start)属性,现在我认为在wildfly子系统中设置这个值是不可能的。 –

回答