如何从standalone.xml文件中的配置在JBoss 7.x中创建JGroups通道?

时间:2012-07-19 08:50:03

标签: osgi jboss7.x jgroups

我正在为JBoss7.x编写一个OSGI服务,我需要为一些与域相关的RPC创建一个新的JChannel。我想使用standalone.xml文件中的一个协议栈定义,如果可以,我想使用共享传输。

我不知道从哪里开始访问信息或如何注入信息。

查看JBoss AS代码,我想我可能需要掌握一个JChannelFactory实例。我将如何在OSGI中执行此操作?

1 个答案:

答案 0 :(得分:1)

不确定这是否是推荐的方法,但确实有效。

首先,获取对JBoss Modular Service Container的引用。这可以在OSGI服务注册表中查找。使用Spring DM / Blueprint:

<osgi:reference id="serviceContainer" interface="org.jboss.msc.service.ServiceContainer" />

在您的代码中,使用服务容器按名称查找给定服务:

ServiceName sn = ServiceName.of("jboss", "jgroups", "stack", "udp");
ServiceController<?> serviceController = serviceContainer.getService(sn);

if (serviceController == null) {
    throw new RuntimeException("Failed to lookup service controller for jboss.jgroups.stack.udp");
}

Service<?> service = serviceController.getService();
Object obj = service.getValue();

ChannelFactory factory = (ChannelFactory) obj;

如果您需要知道可用的服务名称,请拨打dumpServices()上的ServiceContainer以获取日志文件中的列表。

如果使用Maven,则在pom文件中添加对JBoss MSC的依赖:

<dependency>
    <groupId>org.jboss.msc</groupId>
    <artifactId>jboss-msc</artifactId>
    <version>1.0.2.GA</version>
</dependency>

以及访问服务使用的代码时可能需要的任何其他依赖项。在上面的示例中,需要依赖于pom文件中的org.jboss.as/jboss-as-clustering-jgroups和org.jgroups / jgroups库。

您还需要确保将这些服务定义为standalone.xml文件中的功能:

<capability name="org.jgroups"/>
<capability name="org.jboss.as.clustering.jgroups"/>