IDEA中osgi的开发应用指南详解
前言
最近一直在接触osgi的开发任务,了解到本部门都在使用idea作为开发工具,而只有本小组还在使用eclipse。正好赶上版本发布之后的空闲期,因此想要将osgi插件的开发从eclipse转至idea。搜了不少资料,但是均不够详细,经过几天的仔细摸索,终于成功移植了自己的项目,在此也分享给大家在idea上开发osgi,对于idea的使用操作过程。
osgi简介
osgi的全称是open service gateway initiative,直译就是开放服务网关。最新的osgi定义是the dynamic module system for java,即面向java的动态模块化系统。
在传统web开发中,我们为了进行功能的分离,经常会进行模块划分,比如基础信息模块交由a和b做,接口信息模块交由c和d做。最终,再汇集到一起,组成一个完整的项目。在这整一个流程中,我们做到的只是逻辑上的解耦,最终这些模块还是运行于同一服务器上,共享同一个classpath。这时就会出现一个局限性问题,比如现在接口规范改了,我只想停掉接口信息模块,而基础信息模块仍能正常运行,这显然是无法实现的。而使用osgi可以完美解决这个问题,osgi是基于模块(bundle)驱动的,每个模块都有属于自己的classpath和类加载器,模块之间通过服务注册和发现进行关联,每个模块有着自己独立的生命周期,我们可以动态地对模块进行加载、卸载、更新。
新建工程
idea自带osgi开发工具包,因此无需像eclipse一样下载plug-in development,直接使用。
众所周知,idea中的project相当于eclipse中的workspace,idea中的module相当于eclipse中的project,因此在idea中新建project,只是相当于eclipse中建立workspace而已。
settings环境配置
idea中新建工程,不像eclipse中那样,在每次新建project时选择framework,而是在全局设置中先设置好framework工作环境。本项目利用equinor作为osgi framework,附赠一个下载地址
下载解压完成后,点击file->settings,在该界面将framework添加至idea中
添加完毕后,在上面的osgi标签中,便可以选择相应的framework,该界面设置如下图
最后一个import bnd/bndtools projects automatically,查了一下bndtools工具是将普通jar包打包成osgi可用的jar包,由于在建立工程时直接选择osgi作为开发环境,因此该部分……emmmmmm……..应该是无需勾选吧。
配置settings完成后,便可以真正开始新建project了。
开始新建
点击file->new->project,直接选择osgi作为开发环境,该部分如下图
libraries选项卡中可以选择已有library作为该project的library,把你需要用到osgi依赖包导入进来吧,都在equinor的解压包中的plugins目录里,可以慢慢找。
该部分就比较直观了,相信大家都看得懂。注意底下有个more settings,想设置的客官可以设置下,不然你的project名称就变成module的默认名称了,点击finish,新建工程完毕。
project structure设置
新建工程完毕后,关于添加依赖包,osgi设置等全部都集成在了project structure选项卡中。
点击file->project structure,进入设置页面。
project选项卡
modules选项卡
modules中主要需要设置的是dependencies选项卡,该部分相当于eclipse中的classpath路径设置,同时集成了osgi中的import与export。
libraries选项卡
顾名思义,可以自定义依赖包库,如果在该部分设置的依赖包库,只能用于该project中,下面还有另一个global libraries,在那个里面定义的依赖包库,可用于所有的project。该部分就看大家自己的取舍去使用了。
facets
该部分是设置osgi属性的部分,相当于eclipse中manifast的设置。idea中osgi的manifast文件,不像eclipse在编译阶段便生成,而是在打包后才生成,因此所有的设置内容均只能在该选项卡中设置。
该部分使用如下多图所示。
additional contents这个功能,有点类似于eclipse的osgi中的build。添加需要一起打包成为最终jar包的jar包。
而在idea中,没有了runtime选项卡,本来runtime选项卡中的exported与classpath,被拆分。exported已在前述的dependencies选项卡中有所介绍。在eclipse中的classpath添加jar包,可自动在manifast文件中生成bundle-classpath。而在idea中,必须在manifest generration选项卡中的additional properties中,手动添加,如下图所示。
5. artifacts
该部分用于打包项目,使用osgi开发需要的是osgi能够识别的插件包,会在build时自动生成,因此该部分在osgi开发中无需使用。
build工程
全部设置完成后,点击build->build project,便会在相应的目录中输出相应的jar包,将jar包安装至相应地点即可。
总结
eclipse与idea开发osgi,主要是manifast文件的生成过程存在比较大的差异,例如exported与classpath,以及默认所有的源代码中的类,均会自动归入至exported中等。还是那句话,决定一个人技术水平的,永远不会是使用的工具。喜欢使用什么工具,还是一个见仁见智的问题,希望能帮助到对此方面有需求的大家。也希望大家多多支持。