 鲜花( 0)  鸡蛋( 0)
|
OSGi是Open Service Gateway Initiative的简称,该组织建立于1999年,是一个非赢利机构,旨在建立一个开放的服务规范,为通过网络向设备提供服务建立开放的标准。 y5 M# R* ^+ n
OSGI 规范包括了构建开放的可交付网络服务的各方面,OSGI规范又包括了以下子规范。 4 d7 ~+ l7 o0 C N7 N3 v
Framework规范(OSGI核心,提供一个安全的可管理的Java Framework来部署可扩展的Java服务。)
0 W5 E' _" s1 ?+ Y ]! {. h; SPackage Admin Service规范(来管理不同的Bundle之间的引用关系。当Bundle更新或者反安装时判断是否有其他的服务正在使用当前的Bundle)
3 v4 ?- |$ b* ~Start Level规范(定义了启动和停止一个OSGi Service Platform时,不同的Bundles的启动或者停止的先后顺序)
4 C1 T$ V" B. N. R, v0 lPermission Admin Service规范(Bundle是否许可执行另外的Bundle的代码)
) e( D+ g7 y" n! x6 RURL Handlers Service规范(怎样注册URL Schema,如何将java.io.InputStream对象转换为特定的Java对象)
) Y5 C, a$ C1 b- C9 BLog Service规范 (以下略。。。)
9 E3 h3 ?: G1 @- D# UConfiguration Admin Service规范
! Z& f" J7 q9 ]+ B7 {/ o+ |1 \Device Access Specification
& j& b! |( j( u Q4 {6 }% sUser Admin Service Specification/ v) `8 b+ t7 F8 p; o" O
IO Connector Service Specification
4 V5 ?/ u3 W! ~2 Y& s+ B# FHttp Service Specification& v+ K& {0 ?. d% C7 \
Preference Service Specification
7 A2 n4 X( {, q: u! eWire Admin Service Specification
: o1 Y) m3 t7 }3 C' \9 ZXML Parser Service Specification7 t# m( t( p6 P! y6 ^
Metatype Specification
: P+ S7 J/ j( V9 lService Tracker Specification
5 G5 X! q6 {! g* nMeasurment and State Specification& I+ e0 {* W* `2 u& R' A
Position Specification
2 O; B$ y5 Z* h7 w) R V' @, nExecution Environment Specfication# x: O1 L5 z+ J2 P4 @! s$ r
OSGI Framework
! y! X: _, u5 h! B1 [- K& c* MFramework是OSGI Service Platform规范的核心组成部分。它提供了一个通用的、安全可管理的Java framework。通过这个Framework可以支持一种叫做bundles的Service application的部署和扩展。) _5 |$ P7 C$ z. \ E; b
OSGI兼容设备可以下载并且安装OSGI bundles,也可一当他们不再需要的时候删除。bundles安装后会注册一定数量的Services,并被由同一个Framework下的其他bundles使用。
' K% ]" l% x) j7 z" Z, m7 q在一个动态扩展的的 OSGI环境中,Framework管理bundles的安装和更新。同时也管理bundles和Services之间的依赖关系。7 b) y1 ?4 e; a1 Y
Framework提供给bundle开发者必须的资源来在Java平台上开发,为开发的bundles提供了代码动态加载的功能, 也使得开发者开发、部署一个大规模的Services变的很容易。
6 Y0 U3 g. D2 Z其 次,Framework为Java bundle开发者提供了简明一致的编程模型。简化了开发部署的复杂性。这个编程模型允许开发者将自己的接口规范绑定到OSGI环境中的Service。 The selection of a specific implementation, optimized for a specific need or from a specific vendor, can thus be deferred to run-time.1 F/ A7 @# _- b
一个一致的编程模型帮助开发者可以应付一些可估计的危急错误。Framework将会运行在不同的硬件环境上,但一致的接口确保软件组建可以运行在一致的服务接口上。7 X+ ?3 C7 s- I' E3 e6 }( R" [
The Bundle Object& {/ W7 d( q( ]& {
对于每一个安装在OSGI Service Platform的bundle都有一个与之关联的bundle object。一个bundle对象用来管理bundle的生命周期。这项工作通常由Management Agent来做。
2 ^8 Z( r& s: V' X! P. Z3 bBundle State
, G4 F0 }6 I; w/ m" g0 K ]( B, rbundle有以下状态;- G. l* J: f& r( _
INSTALLED – The bundle has been successfully installed. Native code clauses must have been validated.8 `' b* @: k' u0 T' _$ I( b
RESOLVED – All Java classes that the bundle needs are available. This state indicates that the bundle is either ready to be started or has stopped.2 o: k/ X S: H1 r4 u
STARTING – The bundle is being started, and the BundleActivato r. start method has been called and has not yet returned.; C: X+ h# _- k% _: L2 A7 l. W
STOPPING – The bundle is being stopped, and the BundleActivato r. stop method has been called and has not yet returned.. L! y9 s- o( T: O" W3 w- t7 ]# b
ACTIVE – The bundle has successfully started and is running.
6 ?; [8 x3 M( t) _. oUNINSTALLED – The bundle has been uninstalled. It cannot move into another state.7 n3 F1 E6 Q, b: i' F
eclipse 3.0并没有用OSGI替换掉原来的PlugIn机制。它只是做了与标准兼容的工作:给用户提供了一系列的API来访问,在这个过程中,就必须要做一些改 变(比如plugin registry和loading机制)来同OSGI标准完全兼容。最初的Plugin核心只支持静态的扩展,就是说,如果要改变一个已经存在的Plug 就必须重启core,也就是要退出Eclipse并重启。
: U; |! R& y# l# d) `* N有很多人问Eclipse为什么要兼容OSGI规范而不是其他的规范呢?
Y* v: G1 I6 L9 `. k* H在 Eclipse被捐赠出来以前,Eclipse由OTI来开发,其目标是开发一个嵌入式Java软件的开发平台。互联网上现在仍然由很多的连接指向 Visual Age Micro Edition (VAME). 这也是SWT被构思的一个原因,他们想将SWT使用在嵌入式设备中的用户界面。这种渊源关系解释了当时为什么选择OSGI规范。
/ i0 A1 E; Z+ ~另外一个原因是除了OSGI没有其他的规范。OSGI规范在轻量级服务架构应用方面被广泛的支持。而且OSGI被好多电信业的知名公司和一些其他行业的知名公司所支持。他们需要使用OSGI来同Sun的J2ME来抗衡。 |
|