我正在尝试在Infinispan 7.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 之上设置一个 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 组成。我已经将这些添加到独立/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]"
]}
我错过了什么?
您可以按照这些EAP说明在Infinispan服务器之上安装JDBC驱动程序作为核心模块,以安装Cassandra JDBC驱动程序,因为基本服务器的工作方式相同。