0

假设我有这个 OSGI Equinox 应用程序,并且我想知道包已加载,以及它们的状态。为此,我考虑过运行控制台,但我不知道该怎么做。

该应用程序具有以下文件夹结构:

workspace/
config/
features/
bundles/

config/目录包含一个 config.ini 文件以及错误日志文件和一些以插件符号名称命名的文件夹。

我试过从主(主)文件夹运行

java -jar bundles/org.eclipse.osgi_3.6.0.v20100517.jar -console -consoleLog

但我得到的只是一个

osgi> !SESSION 2013-06-04 08:57:53.023 ------------------------------------ ------------ eclipse.buildId=unknown java.version=1.7.0_17 java.vendor=Oracle Corporation BootLoader 常量:OS=win32, ARCH=x86_64, WS=win32, NL=en_US 命令行参数:-console -consoleLog

!ENTRY org.eclipse.osgi 4 0 2013-06-04 08:57:53.512 !MESSAGE 应用程序错误 !STACK 1 java.lang.IllegalStateException: 无法获取应用程序服务。确保 org.eclipse.core.runtime 包已解析并启动(请参阅 config.ini)。在 org.eclipse.core.runtime.internal.adaptor.EclipseAppLauncher.start(EclipseAppLauncher.java:74) 在 org.eclipse.core.runtime.adaptor.EclipseStarter.run(EclipseStarter.java:369) 在 org.eclipse.core .runtime.adaptor.EclipseStarter.run(EclipseStarter.java:179) 在 org.eclipse.core.runtime.adaptor.EclipseStarter.main(EclipseStarter.java:150)

这就提出了知道config.ini文件应该在哪里的问题。如前所述,我知道 有一个config/,虽然我知道这个 RCP 应用程序使用该文件作为其配置文件,但我不太确定我启动的控制台是否可以这样说。为什么?因为我添加了以下行bundles/config.ini无济于事:

osgi.bundles=\
org.eclipse.core.runtime@5:start \
org.bountycastle@3:start, \
org.jdom@3:start, \
org.eclipse.equinox.event@3:start, \
org.eclipse.update.configurator@2:start, \
org.eclipse.equinox.common@2:start, \
org.eclipse.equinox.ds@4:start, \
org.eclipse.equinox.util@4:start, \
org.eclipse.core.runtime@start


osgi.startLevel=10
osgi.bundles.defaultStartLevel=5

欢迎任何线索。提前致谢。

4

2 回答 2

2

如果您使用的是普通的 OSGi(而不是 eclipse 应用程序),您应该将以下内容添加到您的 config.ini 中:

eclipse.ignoreApp=true
osgi.noShutdown=true

此外,如果您不确定使用哪个 config.ini,您可以通过提供 cmd arg 显式定义路径:

java -jar .... -configuration <location of config.ini>
于 2013-06-06T14:25:09.677 回答
1

根据 config.ini 的其余部分,我看到您实际上启动了 org.eclipse.core.runtime 两次:一次 @5:start 和一次(再次)基于默认启动级别的运行级别 5。

您可以尝试删除最后一个 org.eclipse.core.runtime@start 并将第一个更改为运行级别 1 吗?(org.eclipse.core.runtime@1:start) (也许运行级别 2 也可以)。

这样,您可以确保首先启动 core.runtime。

于 2013-06-04T08:08:08.230 回答