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

2023-12-19

我尝试过这里的组件工厂示例link https://github.com/sully6768/karaf-scr-examples/blob/master/src/main/java/org/apache/karaf/scr/examples/componentfactory/ExampleComponentFactoryManager.java。 界面:

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 中。工厂注册成功。但没有显示任何内容。

卡拉夫输出:

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


你可以使用 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");
    }
}
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

karaf 在组件工厂示例中不显示任何错误 的相关文章

随机推荐