我正在尝试在Infinispan7.1服务器中设置jdbc缓存存储。我之前尝试过使用cassandra-cache-store,但显然不再支持它(参见:Infinispan 7.1 Cassandra cache-store)。
有一个cassandra-jdbc驱动程序(https://code.google.com/a/apache-extras.org/p/cassandra-jdbc/)可用,它自己工作得很好。我能够成功地执行对cassandra的查询。
所以我想尝试使用这个驱动程序在cassandra上设置一个jdbc缓存存储。
这是我的配置:
<subsystem xmlns="urn:jboss:domain:datasources:2.0">
<datasources>
<datasource jndi-name="java:jboss/datasources/ExampleDS" pool-name="ExampleDS" enabled="true" use-java-context="true">
<connection-url>jdbc:cassandra://localhost:9160/mykeyspace</connection-url>
<driver>org.apache.cassandra.cql.jdbc.CassandraDriver</driver>
</datasource>
</datasources>
</subsystem>
...
<subsystem xmlns="urn:infinispan:server:core:7.1">
<cache-container name="clustered" default-cache="default" statistics="true">
...
<distributed-cache name="myCounts" mode="SYNC" start="EAGER">
<string-keyed-jdbc-store name="STRING_KEYED_JDBC_STORE" datasource="java:jboss/datasources/ExampleDS" fetch-state="false" purge="false" read-only="false">
<string-keyed-table>
<id-column name="id" type="VARCHAR(255)"/>
<data-column name="count" type="BIGINT"/>
</string-keyed-table>
</string-keyed-jdbc-store>
</distributed-cache>
</cache-container>
</subsystem>cassandra-jdbc驱动程序由1个jar (cassandra-jdbc-2.1.1.jar)和11个依赖jar组成。我已经将这些代码添加到了standalone/lib/ext/中(不知道这是不是正确的位置,因为文档中没有对此进行解释)。
我在启动时得到这个错误:
ERROR [org.jboss.as.controller.management-operation] (Controller Boot Thread) JBAS014613: Operation ("add") failed - address: ([
("subsystem" => "datasources"),
("data-source" => "ExampleDS")
]) - failure description: {"JBAS014771: Services with missing/unavailable dependencies" => [
"jboss.driver-demander.java:jboss/datasources/ExampleDS is missing [jboss.jdbc-driver.org_apache_cassandra_cql_jdbc_CassandraDriver]",
"jboss.data-source.java:jboss/datasources/ExampleDS is missing [jboss.jdbc-driver.org_apache_cassandra_cql_jdbc_CassandraDriver]"
]}我遗漏了什么?
发布于 2015-05-07 20:23:21
您可以在Infinispan Server上使用these EAP instructions to install a JDBC driver as a core module来安装Cassandra JDBC驱动程序,因为基础服务器的工作方式是相同的。
https://stackoverflow.com/questions/29916646
复制相似问题