osgi学习参考资料
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
OSGI
●OSGI(Open Service Gateway Initiative)技术
面象java的动态模型系统
OSGi规范的核心组件是OSGi框架
OSGi服务平台提供在多种网络设备上无需重启的动态改变构造的功能。
●OSGI架构
运行环境:是java环境的规范
模块:定义类的装载策略
生命周期管理:增加了能够被动态安装、开启、关闭、更新和卸载的bundles
服务注册:提供了一个面向bundles的考虑到动态性的协作模型
●Eclipse初识OSGi
Eclipse->run->Run Configurations->OSGi Framework
选中OSGi Framework,右键new,去掉所有勾选的bundles,然后通过查找关键字osgi 找到并选中
然后点击Run,在控制台可以看到
输入:ss
表示环境已经正常
●OSGiHelloWorld
在eclipse中创建一个Plug-in工程
也就是说建立一个标准的OSGi bundle工程
输入bundle相关的元素信息
⏹Plug-in ID指的是Bundle的唯一标识,在实际项目中可以采用类似java的包名组织
策略来保证标识的唯一性
⏹Plug-in Version指的是Bundle的版本
⏹Plug-in Name指的是Bundle的更具有意义的名称
⏹Plug-in Provider指的是Bundle的提供商
⏹剩下最关键的就是Activator部分了,这里填入自己的一个类名就可以了,在工程建立
时eclipse会自动建立这个类
打开自动生成的代码,可以看到此类中有两个方法start和stop;其中start方法是在Bundle被启动的时候调用的,stop是在Bundle被停止的时候调用的
然后分别在这两个方法中各输入一句话
运行
⏹Run Configuration,选中当前工程和最初选择的OSGI的jar包,将其它所有不需要
的bundle去掉
⏹设置当前工程的Auto-Start属性为false
⏹最后点击Run,在Console中出现“osgi>”,表示我们已经成功启动了第一个OSGi应
用
⏹在osgi>提示符下输入ss,然后回车,可以看到如下图
⏹此时我们的自己开发的bundle已经被安装并完成了解析,但是没有启动,接下来输入
start 1(其中1代表ss查看到的id),我们会看到”HelloWorldBundle started!”
被输出了,通过ss可以看到HelloWorld_1.0.0的state变为Active,说明已成功
启动
⏹然后输入stop 1,同样能够输出“HelloWorldBundle stopped!”,同时再用ss
查看,HelloWorld_1.0.0的state又变回RESOLVED.
●OSGI的Bundle中内嵌使用http服务
首先看看在OSGi中怎么使用内嵌的jetty容器
⏹Run Configuration中只选中“org.eclipse.osgi”和
“org.eclipse.equinox.http.jetty”,然后点击"Add Required Bundles"即
可
⏹默认的Jetty监听的端口为80,可又通过指定运行参数
org.osgi.service.http.port来修改围住端口,例如要想使用8080端口,可又切
换到 "Arguments"页(不修改也可以):
⏹启动浏览器,输入:http://localhost或者http://localhost:8080看到如下界
面表示运行成功
创建一个简单的osgi的bundle,由于要结合http服务,需要添加依赖包:找到MANIFEST.MF,切换到Dependencies页面,在Imported Packages里添加如下三个包
✧javax.servlet
✧javax.servlet.http
✧org.osgi.service.http
eclipse有一个内嵌的HttpService的实现,它位于包“org.osgi.service.http”下,一旦这个service所在的osgi bundle启动了,就会有一个内嵌的http容器被启动,这个service就会被注册。
默认地址为:http://localhost,端口为80,可以通过指定参数“org.osgi.service.http.port”参数在运行的时候修改默认端口。
想要提供我们自己定义的http服务,就需要将我们的服务(servlet或其它html页面)注册到这个HttpService中去,这里主要用到HttpService的两个注册方法:
registerResources(String alias, String name, HttpContext context)用来注册诸如表态页面等等
registerServlet(String alias, Servlet servlet, Dictionary initparams, HttpContext context)用来注册servlet类
实现
⏹在src目录下新建一个目录web,在web下新建test.html文件
⏹在src目录下创建一个servlet:PrintNameServlet.在servlet中注入BundleContext的引用
将页面和servlet注册到HttpService中,假如在我们的bundle一运行,这些http 页面就可用,那么,我们可又在Activator里注册服务。
⏹启动bundle,访问:http://localhost:8080/osgi/test.html
●应用布署
创建独立的Equinox环境
⏹在硬盘上创建一个osgi_demo目录
⏹从Eclipse的Plugins目录复制org.eclipse.osgi.xxxxxx.jar到新建目录
⏹修改jar包的名称为:equinox.jar。
⏹然后在相同的目录下编写一个run.bat,其内容为:
Java –jar equinox.jar –console
⏹运行run.bat,如果出现osgi的提示,则说明启动已经成功。
输入ss命令回车后,这
个时候会看到只有一个Active状态的system bundle
导出各Bundle工程为jar
⏹打开DictQueryWeb,打开MANIFEST.MF,选择Runtime页签,设置classpath
⏹添加bin;lib/easymock.jar;lib/junit.jar
⏹选择build页签,选择其中Binary Build里面的lib目录,bin目录和META-INF
目录
⏹选中DictQueryWeb工程,export,选择Deployable plug-ins and fragements
⏹导出之后就可以在plugins目录中看到DictQueryWeb_1.0.0.jar这个bundle了
安装各个Bundle到Equinox中
⏹在osgi_demo文件夹中创建一个目录,然后将第二步导出的四个Bundle复制到此目录
下。
⏹将Eclipse的plugins目录中把我们所需要的
javax.servlet_2.5.0.v200910301333,mons.logging_1.0.
4.v201005080501,org.eclipse.equinox.http.jetty_2.0.0.v20100503,or
g.eclipse.equinox.http.servlet_1.1.0.v20100503,org.eclipse.osgi.s
ervices_3.2.100.v20100503,org.mortbay.jetty.server_6.1.23.v201004
211559,org.mortbay.jetty.util_6.1.23.v201004211559文件复制到
bundles目录下
⏹两种方法将Bundle安装到Equinox中
◆运行run.bat,在osgi>中输入:
Install reference:file:bundles/DictQuery_1.0.0.jar
◆安装完后state为installed
◆依次启动
javax.servlet;mons.logging;org.eclipse.osgi.ser
vice;org.mortbay.jetty;org.eclipse.equinox.http.servlet和
org.eclipse.equinxo.http.jetty, 然后启动我们自己开发的bundle
◆最后输入exit退出系统,以后只需要双击run.bat就可以完成系统的启动
◆或者在osgi_demo目录下创建configuration目录,在configuration目录
下创建config.ini文件,文件内容如下:
osgi.noShutdown=true
osgi.bundles=
reference\:file\:bundles/javax.servlet.jar@start,reference\:f
ile\:bundles/org……logging.jar@start。
Osgi.bundles.defaultStartLevel=4
运行
Java –jar equinox.jar –configuration configuration–console
●Declarative Service版本实现
下载org.eclipse.equinox.ds.jar包放于eclipse的plugins目录下,重新启动eclipse
重构服务发布实现
⏹在前面的例子中我们都是通过在BundleActivator中主动注册服务来提供服务。
这里有
重构两个bundle的代码
⏹去掉Activator:删除LocalDictQuery和RemoteDictQuery工程下的Activator
类,并且修改MANIFEST.MF文件,去掉其中的Bundle-Activator
⏹创建Component配置,在工程中创建OSGI-INF目录,在该目录下创建component.xml
文件,内容如下:
这个是LocalDictQuery Bundle中component.xml,RemoteDictQuery Bundle
的component.xml是类似的写法,只是implementation的class有所不同。
另外
我们不在RemoteDictQuery bundle的MANIFEST.MF中加入Component的设置,
我们只希望系统中有一个DictQuery服务
⏹在MANIFEST.MF引用component配置:
Service-component:OSGI-INF/component.xml
⏹修改servlet
删除BundleContext为参数的构造器,增加对HttpService和QueryService的引
用
⏹在DictQueryWeb工程下创建OSGI-INF目录,并在该目录下创建component.xml文
件:
完成重构就可以启动系统了,在Run Configuration中引用
org.eclipse.equinox.ds bundle,并且设置这个bundle的startlevel为2。