当前位置: 首页 > 面试题库 >

如何部署OSGi应用程序和依赖项?

乐正焕
2023-03-14
问题内容

通过不将数十个JAR依赖项包装到lib目录中,OSGi似乎具有一个小的可部署工件的巨大好处。但是,我找不到任何能告诉我一种简单,可靠的方式来将依赖项部署到容器的方法。例如,我有一个使用CXF和几个Spring子项目的应用程序。如果需要将此应用程序部署到新的Glassfish服务器上,那么最好的方法是确保安装所有依赖项?

我正在使用Maven, 似乎 可以使用某种方法来查看META-INF /
maven目录的钩子,并从pom.xml中提取依赖项列表,然后去获取所需的库(可能是从本地存储库)。有没有办法做到这一点?

Pax插件听起来像是在这样做,但是它似乎基于对Felix容器的增强处理?这不是我想要的,我正在处理一个已经运行的远程容器。

是否有命令行工具而不是GUI这样的东西存在?


问题答案:

有多种方法可以将依赖包分发到OSGi容器。这里是其中的一些:

首先,您需要使用bindex之类的工具为可用的捆绑软件创建XML索引文件。如果使用的是maven-bundle-plugin,它将自动在〜/ .m2 /
repository / repository.xml中维护OBR索引。

使用OBR命令行界面加载索引:

> obr:addUrl file:/Users/derek/.m2/repository/repository.xml

然后要求OBR部署目标捆绑包,并从OBR索引确定依赖性。

> obr:deploy com.paremus.posh.sshd
Target resource(s):
-------------------
   Paremus Posh Ssh Daemon (1.0.23.SNAPSHOT)

Required resource(s):
---------------------
   Paremus Command API (1.0.23.SNAPSHOT)

Optional resource(s):
---------------------
   Paremus Config Admin Commands (1.0.23.SNAPSHOT)
   Paremus OSGi & LDAP Types (1.0.23.SNAPSHOT)

2 Apache Karaf

Karaf支持“功能”,基本上是提供该功能所需的捆绑软件清单:

karaf@root> features:info obr
Description of obr 2.0.0 feature
----------------------------------------------------------------
Feature has no configuration
Feature has no dependencies.
Feature contains followed bundles:
  mvn:org.apache.felix/org.apache.felix.bundlerepository/1.6.4
  mvn:org.apache.karaf.shell/org.apache.karaf.shell.obr/2.0.0
  mvn:org.apache.karaf.features/org.apache.karaf.features.obr/2.0.0

karaf@root> features:install obr

3 Eclipse处女座

处女座使用 计划 来定义组成应用程序的工件,它能够自动提供来自本地和远程存储库的应用程序的依赖项,包括捆绑软件,计划,计划档案(PAR)和配置。

4 Paremus Nimble

Nimble使用OBR(或它自己的扩展)存储库索引来自动部署激活目标捆绑包所需的所有相关捆绑包(并在目标捆绑包停止时将其卸载)。它还可以检测其他依赖项,例如WAB捆绑包需要Web扩展程序,并根据可配置的策略自动安装。

还可以将Nimble配置为启动Glassfish,以便将其功能捆绑到Glassfish容器中。

下面的示例还显示,在激活sshd时会自动安装日志记录支持:

$ posh
________________________________________
Welcome to Paremus Nimble!
Type 'help' for help.
[denzil.0]% nim:add --dry-run com.paremus.posh.sshd@active
-- sorted parts to install --
4325   osgi.resolved.bundle/ch.qos.logback.core:0.9.22
-- start dependency loop --
5729   osgi.resolved.bundle/com.paremus.util.logman:1.0.23.SNAPSHOT
5727   osgi.active.bundle/com.paremus.util.logman:1.0.23.SNAPSHOT
3797   osgi.resolved.bundle/ch.qos.logback.classic:0.9.25.SNAPSHOT
3792   osgi.resolved.bundle/slf4j.api:1.6
-- end dependency loop --
436   osgi.resolved.bundle/org.apache.mina.core:2.0.0.RC1
6533   osgi.resolved.bundle/sshd-core:0.3
398   osgi.resolved.bundle/com.paremus.posh.sshd:1.0.23.SNAPSHOT
396   osgi.active.bundle/com.paremus.posh.sshd:1.0.23.SNAPSHOT

(免责声明:我是Paremus的开发人员)

5 Apache Felix Gogo

gogo是新的RFC147标准命令行外壳。它已在Felix,Karaf,Nimble中使用,不久将在Glassfish中使用。

Gogo允许您以脚本形式运行可以交互键入的所有命令。因此,您可以生成捆绑软件列表以进行安装并将其转换为脚本,甚至可以从工作配置中捕获已安装的捆绑软件,以便可以从头开始重新创建它。



 类似资料:
  • 我的Java应用程序需要org.objectweb.asm库。我在POM中指定了“ASM”依赖项。它将库与应用程序一起部署。尽管如此,该应用程序仍抛出异常NoClassDefFounderRor:org/objectWeb/asm/ClassVisitor。 我怎样才能解决这个问题? 详细信息:我使用的是Glassfish 2.1.1。该应用程序需要泽西1.1.4,泽西需要ASM3.1。我假设gl

  • 我正在研究Terraform以及如何使用它来设置AWS环境。到目前为止,我已经有了用3个公共子网、3个私有子网、一个互联网网关和3个Nat网关设置VPC的脚本。然而,我对如何在私有子网中部署和重新部署应用程序感到困惑? 在我的场景中,我们使用Spring Boot构建微服务。我们的想法是转移到一种状态,在这种状态下,我们可以将弹性负载平衡器连接到公共子网,并在私有子网中的自动缩放组中承载我们的应用

  • 我在Eclipse下开发了一个安装了JBoss工具的项目。当我将应用程序部署到Jboss服务器时,通过Maven提供给项目的一些helper jar文件不会复制到WEB-INF/lib文件夹中。因此,我在运行时得到一个异常。 编辑:pom.xml如下所示: 工件应该部署在下,jboss部署服务器下。 使用: null

  • 问题内容: JAX-RS 1.1规范在第6页上说: 如果不存在Application子类,则必须将添加的servlet命名为: 添加的servlet是什么?可以是任意servlet吗? 如果存在Application子类,并且已经定义了一个servlet,该servlet的servlet初始化参数为: 同样,这里的“ servlet”是什么? 如果存在不由现有Servlet处理的Applicati

  • Requirements 运行一个Spark Streaming应用程序,有下面一些步骤 有管理器的集群-这是任何Spark应用程序都需要的需求,详见部署指南 将应用程序打为jar包-你必须编译你的应用程序为jar包。如果你用spark-submit启动应用程序,你不需要将Spark和Spark Streaming打包进这个jar包。 如果你的应用程序用到了高级源(如kafka,flume),你需

  • 简单的OSGi应用程序与包内的依赖关系。 我在玩karaf。我从写一个简单的Rest应用程序开始。https://github.com/YaroslavTir/osgi-jersey-hibertate/tree/stackoverflow/examples/karaf-rest-core 我将karaf示例作为backbond,使用restendpoint运行我的第一个包非常简单,但是当我添加m