我创建了一个 OSGi 包(用 Kotlin 编写),其中包含一个非常基本的组件,我将其注释为@Component(immediate = true)
. 这个包在使用 Felix 6.0.3 时的行为与预期一样。
@Component(immediate = true)
class Bongo @Activate constructor(
@Reference(service = LoggerFactory::class)
private val logger: Logger
) {
init {
System.err.println("-------------- BONGO!")
logger.info("Started {}", this::class.java)
}
@Activate
fun doIt() {
throw InternalError("BOOM!")
}
}
然后我将这个捆绑包(与其他一些捆绑包)压缩起来,并将其作为一个微不足道的应用程序子系统提供给 Apache Aries。我没有在SUBSYSTEM.MF
这里创建一个明确的,因为默认值似乎是我想要的。Aries 安装并启动我的子系统,然后报告它是ACTIVE
. 我什至已经确认 aBundleActivator
已被正确调用。但是,我没有看到任何证据表明我@Component
已经开始了。看起来 SCR 忽略了它,这看起来很奇怪,因为我认为我需要SCR 来运行应用程序子系统。(我听说声明式服务已经取代了BundleActivator
......)
我浏览了 OSGi 文档,发现除了“启动”它之外,没有提到需要对 OSGi 子系统做任何事情,所以我对如何从这里开始感到困惑。任何人都可以建议我可能错过的任何事情吗?
作为参考,这些是我bndrun
文件中的 Felix / Aries 捆绑包:
org.apache.aries.subsystem.api;version='[2.0.10,2.0.11)',\
org.apache.aries.subsystem.core;version='[2.0.10,2.0.11)',\
org.apache.aries.util;version='[1.1.1,1.1.2)',\
org.apache.felix.bundlerepository;version='[2.0.10,2.0.11)',\
org.apache.felix.configadmin;version='[1.9.18,1.9.19)',\
org.apache.felix.coordinator;version='[1.0.2,1.0.3)',\
org.apache.felix.log;version='[1.2.2,1.2.3)',\
org.apache.felix.logback;version='[1.0.2,1.0.3)',\
org.apache.felix.scr;version='[2.1.20,2.1.21)',\
org.eclipse.equinox.region;version='[1.2.101,1.2.102)',\
谢谢,克里斯