我正在使用BndTools (http://bndtools.org/)来开发OSGI应用程序。一切正常,但我在导出应用程序时有一些想要更改的内容。
我正在尝试实现两件事(我认为它们可能是相关的):
1:将默认的BndTools启动器(aQute.launcher
)替换为自定义启动器(或以.JAR
格式)
如何摆脱或更改默认的BndTools启动器(aQute.launcher)为自定义启动器?
关于这个话题,我唯一能找到的就是这里:http://goo.gl/jYliih
发射器不是内置到 bnd 中,实际的启动策略是参数化的。启动器通过在
-runpath
上放置 JAR 来与 bnd 或 bndrun 文件相关联。.JAR
应该有一个启动器插件标头才能成为启动器。如果在-runpath
上找不到启动器,则将使用内置biz.aQute.launcher
。
原因是我需要我的应用程序接受命令参数,并且不干扰 aQute 启动器(像所有 -run args 一样)。另一方面,我想摆脱启动应用程序的批处理.bat/.sh
方法,并使用单个.jar
文件启动应用程序。
这可能吗?
2:自定义导出的文件结构
默认情况下,BndTools 在导出应用时会创建此文件结构:
jar/
-> 这是 OSGI jar 捆绑包文件夹
aQute/
-> 默认的 BndTools 启动器(启动器.class里面)
META-INF/
-> 为什么这里有一个 META-INF 文件夹?这不是一个 JAR
launcher.properties
-> 启动器属性
start.sh
--> 从此批处理文件启动启动器.class。
start.bat
/与 JAR 相比,这样做的好处在哪里?
基本上我想删除aQute
,META-INF
和start.*
文件,并为二进制文件添加一个bin
文件夹。
这应该可以通过"Ant","Maven"或"Gridle"脚本来实现。但是我可以创建一个没有 BndTools 支持的"BndTools 项目"或"Gradle 项目"。我安装了"BndTools Gradle插件",但我在任何地方都找不到有关此主题的任何有用文档。
希望有人可以帮助我或指出正确的方向。问候。
(这个问题在bndtools组列表中也被问到)
我有点困惑,因为你的愿望似乎得到了满足。您可以将 bndrun 文件导出到单个可执行 JAR。在 bndtools 程序中,您可以通过获取对象服务,然后获取"launcher.arguments"服务属性来访问命令行参数。这是提供给启动器主方法的原始 String[]。
@Reference(target=“(launcher.arguments=*)”)
void setArgs( Map<String,Object> args ) {
… = (String[]) args.get( “launcher.arguments”;
}
导出的 JAR 是一个可执行的 JAR。JPM可以很容易地将其转换为本地可执行文件。
jpm install -n mycode mycode.jar
您可以从 https://github.com/bndtools/jpmcli 安装 jpm
罗伯特:谢谢彼得,启动器参数代码片段正是我所需要的。
关于文件夹结构:
我需要我的捆绑包可更新。如果我将所有捆绑包嵌入.Jar 然后将无法更新它们。我只需要打包启动器,同时将捆绑包放在外面。
BndTools 有两个导出选项。 1,您可以在其中嵌入整个启动器和所有捆绑包到一个 JAR 中。或者选项 2 是将捆绑包放在 lib 目录中,并通过 shell 脚本(start.bat、start.sh)启动它们。我正在寻找一种无外壳脚本的解决方案。
彼得:即使捆绑包在里面,只要不清除框架的存储区域,您仍然可以更新它们。例如,您可以轻松地包含文件安装并从目录中加载捆绑包或使用另一个管理代理 Apache Ace。
从我的角度来看,当前的JAR导出(我实际上非常不喜欢目录导出,它很混乱)已经很好了。它有一个非常好的发布模型,只有一个易于版本控制和更新的文件。使用JPM,您可以将其安装在任何系统上。
因此,如果您想要其他东西,则必须创建自己的出口商......