java - Maven OSGi 捆绑

标签 java osgi

我正在使用 maven felix 插件来创建 OSGi 包,但是假设您有一个包“com.example”存在于project1和project2中。此外,project2 依赖于 project1。

如果您导出项目 2 中的包,它将包含项目 2 中的代码和项目 1 中的代码。对我来说,这真是奇怪的行为。我能想到他们启用这种行为的唯一原因是因为 OSGi 以某种方式需要它? (我已经看过 http://felix.apache.org/site/apache-felix-maven-bundle-plugin-bnd.html 但似乎找不到关闭它的方法)

如果两个 jar(A 和 B)导出相同的包,但其中包含不同的类,并且第三个 jar(C)依赖于该包,我会假设 C 在运行时可以看到 A 和 B。或者 OSGi 是否需要每个 jar 不同的包?

如果 OSGi 没有强制执行此操作,我如何关闭此“功能”?

如果 OSGi 强制这样做,那么......为什么?

更新

Christian 提供的答案明确了不同 jar 中不同包的 OSGi 要求。但是我仍然对 felix 有一个问题,我有一个“api”jar,其中包含:

  • com.example.api:实际接口(interface)
  • com.example:工厂类、实用程序类...

以及一个实现包,其中包含:

  • com.example.impl

现在,当我使用 felix 构建实现包并导出“com.example.impl”时,它确实包含“com.example.impl”中的所有内容,但由于某种原因,它还包含“com.example.impl”中的所有类。示例”(不是 .api 中的示例)。我尝试过的任何设置组合都不会阻止 felix 由于某种原因添加“基本”包...

所以基本上在“impl”项目的生成的 jar 中,我实际上有 api 包中的 com.example.MyFactory 类。我怎样才能阻止这个?

最佳答案

OSGi 并不强制要求您在两个项目中使用相同的包。事实上,您应该避免在具有不同内容的两个 bundle 中使用相同的软件包/版本组合。

在 OSGi 中,当 bundle 从已安装到已解决时,就会发生连接。在该步骤中,框架将每个 Import-Package 语句与匹配名称和版本范围的导出包进行匹配。在 OSGi 中,即使多个包导出相同的包,也只会将一个包连接到每个包。这与标准 java 不同,在标准 java 中,您将混合拥有该包的所有 jar 中的类,这可能会产生相当不可预测的结果。

在 OSGi 中,存在一种模式,即在多个 bundle 中具有相同的包。它经常用于 OSGi 的官方 API。当您实现 API 时,您还包括 API 包,并具有 API 包的 Import-Package 和 Export-Package 语句。这允许安装实现包而无需额外的 API 包。即使有多个包含 API 的包,这种方法也能很好地工作,因为框架会选择其中一个 API 包,并将所有其他包连接到同一包。所以他们都看到同一组类并且不存在冲突。

您也可以为自己的应用程序执行此操作,但更常见的做法是将 API 包放在一个 bundle 中,而所有其他应用程序只需导入它。

您可以在 apache felix OSGi Frequently Asked Questions 找到一些信息

<小时/>

回答您更新的问题。我猜你只导出 com.example.api 包。因此 Maven Bundle 插件知道它可以使用 Import-Package 语句引用此包。由于 com.example 未导出,因此插件知道导入包将不起作用。所以它嵌入了类。

因此,您应该注意的是,您需要导出其他 bundle 所需的所有包。顺便提一句。您通常不会在 OSGi 中导出 impl 包。相反,您将实现隐藏在服务后面。服务接口(interface)放在API中。然后,impl 包实现该接口(interface)并将 impl 导出为 OSGi 服务。因此其他 bundle 可以通过其接口(interface)绑定(bind)该服务,并且整个 impl 可以保持私有(private)。

关于java - Maven OSGi 捆绑,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/26796526/

相关文章:

java - Gradle 'APP' 项目刷新失败原因 :Java. Lang.NullPointerException

Java Dom4j SAXReader 和 XMLWriter 导致多个换行

java - X流: duplicate field exception

java - 从嵌入式 OSGi 框架使用 Log4j2

java - 如何访问 karaf 功能文件中的系统属性

java - OSGI 上的 Shiro 注释

java - Spring Boot 。 ModelAndView addObject 不是替换标签

java字节数组转换为字符串,但在不同的操作系统中结果不同

java - Felix - 如何在 bundle 更新时正确重新注册服务?

java - 将 RXTX 集成到 Raspberry Pi 上的 OSGi 包时 Unresolved 要求