gpt4 book ai didi

java - karaf 在组件工厂示例中不显示任何错误

转载 作者:太空宇宙 更新时间:2023-11-04 13:15:34 27 4
gpt4 key购买 nike

我已经尝试过此 link 中的组件工厂示例。接口(interface):

package com.java.examplefactoryservice;

public interface ExampleFactoryService {
public void start();

public void stop();
}

工厂提供商:

package com.java.examplecomponentfactoryserviceprovider;

import java.util.Map;

import org.apache.felix.scr.annotations.Activate;
import org.apache.felix.scr.annotations.Component;

import com.java.examplefactoryservice.ExampleFactoryService;

@Component(name = "ExampleComponentFactoryServiceProvider", factory = "example.factory.provider")
public class ExampleComponentFactoryServiceProvider implements ExampleFactoryService {

@Activate
public void activate(Map<String, Object> properties) {
System.out.println("Actiavted!!!");
}

@Override
public void start() {
System.out.println("Started !!!!");
}

@Override
public void stop() {
System.out.println("Stopped!!!");
}

}

工厂经理:

package com.java.examplecomponentfatorymanager;

import java.util.Map;

import org.apache.felix.scr.annotations.Activate;
import org.apache.felix.scr.annotations.Component;
import org.apache.felix.scr.annotations.Reference;
import org.osgi.service.component.ComponentFactory;
import org.osgi.service.component.ComponentInstance;

import com.java.examplefactoryservice.ExampleFactoryService;

@Component(name = "ExampleComponentFactoryManager", enabled = true, immediate = true)
public class ExampleComponentFactoryManager {

@Reference(target = "(component.factory=example.factory.provider)", bind = "setFactory", unbind = "unsetFactory")
private ComponentFactory factory;

private ComponentInstance instance;

private ExampleFactoryService service;

@Activate
public void activate(Map<String, Object> properties) {
System.out.println("activate in manager !!!!");
instance = factory.newInstance(null);
service = (ExampleFactoryService) instance.getInstance();
System.out.println("service = " + service.toString());
}

public void setFactory(final ComponentFactory factory) {
this.factory = factory;
System.out.println("setfactory called");
}

public void unsetFactory(ComponentFactory factory) {
this.factory = null;
System.out.println("Unset factory called");
}

}

一切都编译良好并安装在 karaf 2.3.10 中。工厂注册成功。但什么也没显示。

Karaf 输出:

[  71] [Active     ] [            ] [   80] osgi.cmpn (4.3.1.201210102024)
[ 79] [Active ] [ ] [ 80] testI (0.0.1.SNAPSHOT)
[ 80] [Active ] [ ] [ 80] testImpl (0.0.3.SNAPSHOT)
[ 110] [Active ] [ ] [ 80] Apache Felix Declarative Services (1.6.0)
[ 140] [Active ] [ ] [ 80] ExampleFactoryService (0.0.1.SNAPSHOT)
[ 152] [Active ] [ ] [ 80] ExampleComponentFactoryServiceProvider (0.0.1.SNAPSHOT)
[ 158] [Active ] [ ] [ 80] ExampleComponentFatoryManager (0.0.1.SNAPSHOT)

scr:列表输出

[9   ] [FACTORY         ] ExampleComponentFactoryServiceProvider

scr:详细信息

scr:deactivate    scr:details
karaf@root> scr:details ExampleComponentFactoryServiceProvider
Component Details
Name : ExampleComponentFactoryServiceProvider
State : FACTORY
Properties :
service.vendor=The Apache Software Foundation
component.factory=example.factory.provider
component.name=ExampleComponentFactoryServiceProvider
References

pom.xml

<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>ExampleComponentFatoryManager</groupId>
<artifactId>ExampleComponentFatoryManager</artifactId>
<version>0.0.1-SNAPSHOT</version>
<build>
<sourceDirectory>src</sourceDirectory>
<plugins>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-compiler-plugin</artifactId>
<version>2.3.2</version>
<configuration>
<source>1.6</source>
<target>1.6</target>
</configuration>
</plugin>
<plugin>
<groupId>org.apache.felix</groupId>
<artifactId>maven-bundle-plugin</artifactId>
<extensions>true</extensions>
<version>2.3.5</version>
<configuration>
<instructions>
<Import-Package>
*,
javax.servlet*;version="[2.5,4)"
</Import-Package>
</instructions>
</configuration>
</plugin>
<plugin>
<groupId>org.apache.felix</groupId>
<artifactId>maven-scr-plugin</artifactId>
<version>1.14.0</version>
<executions>
<execution>
<id>generate-scr-scrdescriptor</id>
<goals>
<goal>scr</goal>
</goals>
</execution>
</executions>
</plugin>
</plugins>
</build>
<dependencies>
<dependency>
<groupId>org.apache.felix</groupId>
<artifactId>org.apache.felix.scr.annotations</artifactId>
<version>1.9.6</version>
</dependency>
<dependency>
<groupId>org.apache.felix</groupId>
<artifactId>org.osgi.compendium</artifactId>
<version>1.4.0</version>
</dependency>
<dependency>
<groupId>org.osgi</groupId>
<artifactId>org.osgi.core</artifactId>
<version>4.3.1</version>
<scope>provided</scope>
</dependency>
<dependency>
<groupId>ExampleFactoryService</groupId>
<artifactId>ExampleFactoryService</artifactId>
<version>0.0.1-SNAPSHOT</version>
</dependency>
</dependencies>
</project>

最初我尝试在 karaf 命令行中安装 bundle 而不是名称,它显示 bundle 的绝对路径。一段时间后,我尝试将 bundle 放入部署中,它显示了 bundle 的确切名称。我不明白 karaf 的行为,为什么它在进行正确的命令行安装时不显示包名称。它根本没有显示任何错误[依赖/编译/连线执行]。谁能告诉我 bundle 中有什么问题吗?

最佳答案

你可以使用 import aQute.bnd.annotation 代替为 karaf 导入 o​​rg.apache.felix.scr.annotations。

引用下面的代码

@Component(name="ExampleComponentFactoryManager",immediate=true,enabled=true)
public class ExampleComponentFactoryManager
{

private static final Logger LOG = LoggerFactory.getLogger(ExampleComponentFactoryManager.class);

private ComponentFactory factory;

// @Reference(target = "(component.factory=example.factory.provider)",unbind = "unsetFactory")
//private ComponentFactory factory;

private ComponentInstance instance;

private ExampleFactoryService service;

@Activate
public void activate(Map<String, Object> properties) {
LOG.info("activation factorymanager");
instance=factory.newInstance(null);
service =(ExampleFactoryService)instance.getInstance();
LOG.info("service instance from factory "+service.toString());

}
@Reference(target = "(component.factory=example.factory.provider)",unbind = "unsetFactory")
public void setFactory(final ComponentFactory factory) {
LOG.info("set Factory");
this.factory = factory;
System.out.println("setfactory called");
}

public void unsetFactory(ComponentFactory factory) {
this.factory = null;
System.out.println("Unset factory called");
}
}

关于java - karaf 在组件工厂示例中不显示任何错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33567350/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com