karaf не отображает никаких ошибок во время примера фабрики компонентов

я пробовал пример фабрики компонентов из этого ссылка. интерфейс:

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

пом.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, почему он не показывает имя пакета при правильной установке из командной строки. И это вообще не показывает никаких ошибок [зависимость/компиляция/wiredexecption]. Кто-нибудь, подскажите, что не так в комплекте?


person Shriram    schedule 06.11.2015    source источник
comment
Это весь вывод scr:list? ExampleComponentFactoryManager отсутствует   -  person Neil Bartlett    schedule 06.11.2015
comment
да. только один пакет, который я установил. ExampleComponentFactoryManager не отображается в scr:list.   -  person Shriram    schedule 06.11.2015
comment
@Neil, по крайней мере, я ожидаю, что СОП будет напечатана. Но ничего не печатается. Также, если я устанавливаю его через cmd, имя пакета строки не отображается, вместо этого отображается абсолютный путь. Я не понял поведения Карафа. Это проблема с производительностью в karaf или я что-то не так делаю?   -  person Shriram    schedule 06.11.2015
comment
Я думаю, что есть ошибка в построении бандла, потому что ExampleComponentFactoryManager вообще не появляется. Однако я могу только догадываться, потому что опубликован только исходный код Java.   -  person Neil Bartlett    schedule 06.11.2015
comment
Построение пакета ничего не делает. Потому что он правильно развернут с именем, как и ожидалось. Если хотите, я могу опубликовать pom.xml.   -  person Shriram    schedule 08.11.2015
comment
@Нил, большое спасибо. Проблема с файлом pom.xml. ‹packagin›bundle‹/packaging› отсутствует в моем pom.xml. Из-за этого он просто создает обычный файл jar вместо файла jar osgi.   -  person Shriram    schedule 08.11.2015
comment
Когда я пытаюсь запустить метод активации пакета, он вызывается дважды и создаются два объекта службы? я не знаю почему?   -  person Shriram    schedule 08.11.2015


Ответы (1)


вы можете импортировать aQute.bnd.annotation вместо импорта org.apache.felix.scr.annotations для karaf.

см. ниже код

@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");
    }
}
person Guruprasad Das    schedule 03.08.2017