我想在我的应用程序中嵌入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
而不会生效。
答案 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容器)中注册实现此接口的服务时才要使用外部类加载器中的此包。