问题1. 按照教程中建立osgi的插件,但在运行时按照教程选择Target platform运行却出现异常
在教程使用 Equinox 开发 OSGi 应用程序 中运行插件时,选择Target Platform中的依赖组件,只选择了org.eclipse.osgi 如图
但在运行时,却在console中输出一堆的异常
问题2. 通过java -jar org.eclipse.osgi.xx.jar -console 运行插件时无响应
在启动osgi框架时
java -jar org.eclipse.osgi_3.12.100.v20180210-1608.jar -console
在console中却没有任何输出,并没有出现提示
osgi>
问题3. 在运行插件时,提示不能找到JavaSE 1.8 执行环境的提示
xxxxx Missing Constraint: Bundle-RequiredExecutionEnvironment: JavaSE-1.8
分析
这些都是因osgi的版本差异引起的问题,先前的教程和资料都比较早了,随着osgi的升级,已经有了差异。
出现问题1的环境采用IDE是Version: Oxygen.3a Release (4.7.3a),里面带有的osgi的版本已经是3.12.*了,而问题2所使用的版本也是比较高的了。这一版本的osgi包,还依赖如下几个包
org.eclipse.equinox.console
org.apache.felix.gogo.runtime
org.apache.felix.gogo.command
org.apache.felix.gogo.shell
因而在IDE中运行时要一起选择它们,在控制台中运行也需要连同它们一起运行。
对策
- 对问题1,2
在IDE中运行时可以在"Run Configuration --> Bundles 中从1000+个筛选",也可以把自己要使用的osgi版本及所有组件都放置在一个目录中,然后在windows ->Preference ->plugin development ->Target Platform中新建一个Target platform, 然后选择该目录
之后在运行插件时,则仅在自己定义的target platform中选择要加载的组件了。运行后可以看到,只有这几个bundle被加载
osgi> ss
"Framework is launched."
id State Bundle
0 ACTIVE org.eclipse.osgi_3.12.100.v20180210-1608
1 ACTIVE org.eclipse.equinox.console_1.1.300.v20170512-2111
2 ACTIVE HelloOsgi_1.0.0.qualifier
3 ACTIVE HelloUserOsgi_1.0.0.qualifier
4 ACTIVE org.apache.felix.gogo.runtime_0.10.0.v201209301036
5 ACTIVE org.apache.felix.gogo.shell_0.10.0.v201212101605
6 ACTIVE org.apache.felix.gogo.command_0.10.0.v201209301215
osgi>
在console中运行时,则要添加config.ini,并在其中配置要加载的bundles
增加configuration目录,在下面创建文件config.ini
文件config.ini内容如下
osgi.bundles=file\:org.eclipse.equinox.console_1.1.300.v20170512-2111.jar@start,
file:\org.apache.felix.gogo.runtime_0.10.0.v201209301036.jar@start,
file:\org.apache.felix.gogo.shell_0.10.0.v201212101605.jar@start,
file:\org.apache.felix.gogo.command_0.10.0.v201209301215.jar@start
文件目录如下-
对问题3
则可以改为使用支持JaveSE-1.8的osgi版本(如3.12),或者在bundle的MANIFEST.MF文件的"Execution Environment "中增加J2SE-1.5的设置(如果在插件内使用了JDK8的特性在运行中可能会出现问题,参见"已验证"),如图:
已验证
在设置"Execution Environment "中含J2SE-1.5的插件中,不可以使用某些高级特性,比如发现如果使用了@Override 注解,但编译生成bundle时会给出错误提示,虽然生成了bundle,在运行中引用该类对应的服务时也会提示没有实现接口中的方法。
public class HelloImpl implements Hello {
//if you want to run it in j2se-1.5 execution environments, annotation @Override cannot be used
//@Override
public String sayHello() {
return "Hello osgiTester !";
}
}
参考资料
java -jar org.eclipse.osgi_version.jar -console 报错
使用 Equinox 开发 OSGi 应用程序