0

我们在 Karaf 4.0.3 中加载了不同的 OSGi 包,javax.sql.DataSource并由pax-jdbc-config. 例如,为不同的数据库配置了两个数据源:

karaf@root()> service:list DataSource
[javax.sql.DataSource]
----------------------
 dataSourceName = datasourceA
 felix.fileinstall.filename = file:/opt/karaf/etc/org.ops4j.datasource-dba.cfg
 osgi.jdbc.driver.name = mysql-pool
 osgi.jndi.service.name = datasourceA
 password = secretpassword
 service.bundleid = 207
 service.factoryPid = org.ops4j.datasource
 service.id = 276
 service.pid = org.ops4j.datasource.2ab06071-d3fa-4d7e-b508-19f36892cb7e
 service.scope = singleton
 url = jdbc:mysql://mysql.example.com/dba
 user = dbuser
Provided by : 
 OPS4J Pax JDBC Config (207)
Used by: 
 MODULE B (29)

[javax.sql.DataSource]
----------------------
 dataSourceName = datasourceB
 felix.fileinstall.filename = file:/opt/karaf/etc/org.ops4j.datasource-dbb.cfg
 osgi.jdbc.driver.name = PostgreSQL JDBC Driver-pool
 osgi.jndi.service.name = datasourceB
 password = secretpassword
 service.bundleid = 207
 service.factoryPid = org.ops4j.datasource
 service.id = 278
 service.pid = org.ops4j.datasource.a7b84423-a605-4010-9806-db7bcc0bccd4
 service.scope = singleton
 url = jdbc:postgresql://postgresql.example.com/dbb
 user = dbuser
Provided by : 
 OPS4J Pax JDBC Config (207)

我的问题是 bundle MODULE B应该使用datasourceB。它被配置为在所有源文件和blueprint.xml中使用datasourceB

...
<reference id="datasourceB" interface="javax.sql.DataSource"/>
...

我真的不明白,karaf 捆绑包使用不同的数据源有多容易。

并且当datasourceA配置文件被删除时,MODULE B正确使用datasourceB

这个问题是关于配置文件的错误顺序还是什么?

编辑:
我发现当我删除datasourceA配置文件并因此 Karaf 删除该 DataSource (不存在于service:list DataSource)时,MODULE B正确使用datasourceB

但我仍然不知道为什么会这样。我是否错过了阅读有关此的一些文档?是pax-jdbc-config问题还是卡拉夫问题?

4

1 回答 1

2

当您引用数据源时,您可以使用过滤器来指示您想要的那个:

<reference id="datasourceB" interface="javax.sql.DataSource" filter="(dataSourceName=datasourceB)" />
于 2016-09-06T12:12:06.057 回答