 鲜花( 0)  鸡蛋( 0)
|
OSGi是Open Service Gateway Initiative的简称,该组织建立于1999年,是一个非赢利机构,旨在建立一个开放的服务规范,为通过网络向设备提供服务建立开放的标准。
! l' J" o, B' |4 r* @4 r9 aOSGI 规范包括了构建开放的可交付网络服务的各方面,OSGI规范又包括了以下子规范。 - t$ B" `7 A# A8 p; ^
Framework规范(OSGI核心,提供一个安全的可管理的Java Framework来部署可扩展的Java服务。) & g4 u2 y. {+ c$ \
Package Admin Service规范(来管理不同的Bundle之间的引用关系。当Bundle更新或者反安装时判断是否有其他的服务正在使用当前的Bundle)
; c2 v8 H8 D9 @% Y6 q5 l( dStart Level规范(定义了启动和停止一个OSGi Service Platform时,不同的Bundles的启动或者停止的先后顺序)8 } Q$ O% Z2 T! t
Permission Admin Service规范(Bundle是否许可执行另外的Bundle的代码)
/ F7 K2 x9 X$ k: R$ N/ LURL Handlers Service规范(怎样注册URL Schema,如何将java.io.InputStream对象转换为特定的Java对象)
7 \3 z9 C9 T. Z: LLog Service规范 (以下略。。。)
% k# f$ e, L7 H' S* {7 y4 AConfiguration Admin Service规范
3 @: o2 A9 S1 YDevice Access Specification2 z! Z- G9 X; s) j" V
User Admin Service Specification! ?/ E- S/ P: B9 Q- g. \
IO Connector Service Specification+ q& Z4 d6 ~ J( M7 `; N
Http Service Specification
( w# {1 |" B5 ]" T7 j* lPreference Service Specification
5 s6 `7 g" R# y* b0 Z( ^Wire Admin Service Specification
4 r( L9 z( _" AXML Parser Service Specification& K" E. T& b9 h n
Metatype Specification
7 \8 w4 N( Z: v2 z9 MService Tracker Specification$ A) G* {' y- {+ }. W, f* E h
Measurment and State Specification
7 f2 L! ~5 f2 O! ~* aPosition Specification# Z. T1 z% ^0 D ]8 T" @
Execution Environment Specfication
* X# {2 u V( r1 j3 [3 n$ e# A, dOSGI Framework
2 Q" L/ j2 R" L1 z: [0 pFramework是OSGI Service Platform规范的核心组成部分。它提供了一个通用的、安全可管理的Java framework。通过这个Framework可以支持一种叫做bundles的Service application的部署和扩展。8 k9 ~2 |1 |; T: k' q
OSGI兼容设备可以下载并且安装OSGI bundles,也可一当他们不再需要的时候删除。bundles安装后会注册一定数量的Services,并被由同一个Framework下的其他bundles使用。/ @/ d' @7 \. K. @4 ?
在一个动态扩展的的 OSGI环境中,Framework管理bundles的安装和更新。同时也管理bundles和Services之间的依赖关系。# b+ ?" t9 d0 l. l8 f
Framework提供给bundle开发者必须的资源来在Java平台上开发,为开发的bundles提供了代码动态加载的功能, 也使得开发者开发、部署一个大规模的Services变的很容易。
3 c+ `. q4 Y! H+ p7 c; t. F" t其 次,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.* o% ]: v4 w7 G+ ]
一个一致的编程模型帮助开发者可以应付一些可估计的危急错误。Framework将会运行在不同的硬件环境上,但一致的接口确保软件组建可以运行在一致的服务接口上。7 j7 X9 A+ i8 |/ z; a: B9 j5 x0 L
The Bundle Object- m! i1 m4 F; `3 m9 h: m, H
对于每一个安装在OSGI Service Platform的bundle都有一个与之关联的bundle object。一个bundle对象用来管理bundle的生命周期。这项工作通常由Management Agent来做。
: @& r3 Q8 S7 R$ z3 t7 wBundle State
# f3 D" @5 L' K2 q ~, qbundle有以下状态;7 ? l/ W. k# P1 B0 S( E
INSTALLED – The bundle has been successfully installed. Native code clauses must have been validated.
' y# ]! @3 c+ E1 d1 H* M) [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.
8 y4 [) t" M! S2 RSTARTING – The bundle is being started, and the BundleActivato r. start method has been called and has not yet returned.
$ d# D2 T @6 @/ O4 GSTOPPING – The bundle is being stopped, and the BundleActivato r. stop method has been called and has not yet returned.
/ ~" h9 Y, N& {ACTIVE – The bundle has successfully started and is running.
# U8 R# F, M+ K" I% zUNINSTALLED – The bundle has been uninstalled. It cannot move into another state.
8 H$ @3 C5 d& S) ]2 L/ k! |# f& O. d: Ieclipse 3.0并没有用OSGI替换掉原来的PlugIn机制。它只是做了与标准兼容的工作:给用户提供了一系列的API来访问,在这个过程中,就必须要做一些改 变(比如plugin registry和loading机制)来同OSGI标准完全兼容。最初的Plugin核心只支持静态的扩展,就是说,如果要改变一个已经存在的Plug 就必须重启core,也就是要退出Eclipse并重启。
2 Z' G$ \+ R8 R' z, f0 W9 H( [有很多人问Eclipse为什么要兼容OSGI规范而不是其他的规范呢?. V8 C5 M. P& J1 f" W
在 Eclipse被捐赠出来以前,Eclipse由OTI来开发,其目标是开发一个嵌入式Java软件的开发平台。互联网上现在仍然由很多的连接指向 Visual Age Micro Edition (VAME). 这也是SWT被构思的一个原因,他们想将SWT使用在嵌入式设备中的用户界面。这种渊源关系解释了当时为什么选择OSGI规范。. q0 d1 ?2 W3 }' ^% X4 s) F
另外一个原因是除了OSGI没有其他的规范。OSGI规范在轻量级服务架构应用方面被广泛的支持。而且OSGI被好多电信业的知名公司和一些其他行业的知名公司所支持。他们需要使用OSGI来同Sun的J2ME来抗衡。 |
|