如何为嵌入式Apache Felix配置LogService?

时间:2016-02-13 19:25:28

标签: java logging osgi apache-felix osgi-bundle

我想在我的应用程序中嵌入Apache Felix。它的工作情况很好,除非我的一个包开始取决于osg.osgi.service.log

以下是我启动嵌入式Felix的方法:

    Map<String, Object> config = new HashMap<>();
    config.put(Constants.FRAMEWORK_SYSTEMPACKAGES_EXTRA, "org.osgi.service.log,my.custom.package");
    config.put(FelixConstants.LOG_LEVEL_PROP, "3");

    felix = new Felix(config);

    try {
        felix.start();
    } catch (BundleException e) {
        //...
    }

    felix.getBundleContext().installBundle("file:my-bundle.jar").start();

这是我的捆绑清单的样子:

    Export-Package: my.custom.bundle;uses:="my.custom.package,org.osgi.framework,org.osgi.service.log";version="0.0.1"
    Import-Package: my.custom.package,org.osgi.framework;version="[1.5,2)",org.osgi.service.log;version="[1.3,2)"

安装我的软件包后,我收到了以下异常日志:

    org.osgi.framework.BundleException: Unable to resolve my.custom.bundle [1](R 1.0): missing requirement [my.custom.bundle [1](R 1.0)] osgi.wiring.package; (&(osgi.wiring.package=org.osgi.service.log (version>=1.3.0)(!(version>=2.0.0))) Unresolved requirements: [[my.custom.bundle [1](R 1.0)] osgi.wiring.package; (&(osgi.wiring.package=org.osgi.service.log)(version>=1.3.0)(!(version>=2.0.0)))]
        at org.apache.felix.framework.Felix.resolveBundleRevision(Felix.java:4111)
        at org.apache.felix.framework.Felix.startBundle(Felix.java:2117)
        at org.apache.felix.framework.Felix.setActiveStartLevel(Felix.java:1371)
        at org.apache.felix.framework.FrameworkStartLevelImpl.run(FrameworkStartLevelImpl.java:308)
        at java.lang.Thread.run(Thread.java:745)

我尝试导入以将org.apache.felix.log添加到FRAMEWORK_SYSTEMPACKAGES_EXTRA,或将org.apache.felix.log.Activator添加到SYSTEMBUNDLE_ACTIVATORS_PROP而不会生效。

1 个答案:

答案 0 :(得分:1)

如果您可以将包含org.osgi.service.log的软件包安装到嵌入式OSGi容器中,那将是最好的。

如果您真的想从外部类加载器中使用它,则应在 org.osgi.framework.system.packages.extra 配置中指定软件包的版本。

config.put(Constants.FRAMEWORK_SYSTEMPACKAGES_EXTRA, "org.osgi.service.log;version="x.x.x",my.custom.package");

其中x.x.x应替换为类路径中包的版本。应大于或等于1.3.0且低于2.0.0。

我可以想象只有在容器应用程序(嵌入OSGi容器)中注册实现此接口的服务时才要使用外部类加载器中的此包。