 鲜花( 0)  鸡蛋( 0)
|
OSGi是Open Service Gateway Initiative的简称,该组织建立于1999年,是一个非赢利机构,旨在建立一个开放的服务规范,为通过网络向设备提供服务建立开放的标准。
. F7 Y+ s1 X: _8 b( v: IOSGI 规范包括了构建开放的可交付网络服务的各方面,OSGI规范又包括了以下子规范。
4 j& _- w6 b) [0 j* b' {Framework规范(OSGI核心,提供一个安全的可管理的Java Framework来部署可扩展的Java服务。)
: C! f- a2 r" w8 ?% A+ n5 s# pPackage Admin Service规范(来管理不同的Bundle之间的引用关系。当Bundle更新或者反安装时判断是否有其他的服务正在使用当前的Bundle)( Z% y- t/ V% ]
Start Level规范(定义了启动和停止一个OSGi Service Platform时,不同的Bundles的启动或者停止的先后顺序)
, ]; I' n1 ^7 {* sPermission Admin Service规范(Bundle是否许可执行另外的Bundle的代码)' g2 Q- p+ r( h9 u+ z0 c
URL Handlers Service规范(怎样注册URL Schema,如何将java.io.InputStream对象转换为特定的Java对象)' G# `: k/ X8 p4 ]% k8 U' ^% h
Log Service规范 (以下略。。。)
$ L% r' ?, @' f/ h% w9 r( c7 bConfiguration Admin Service规范, F1 J3 O" m# f. _$ ^
Device Access Specification
( p3 N% h C, F% cUser Admin Service Specification
; X3 V u' L3 e" ^/ dIO Connector Service Specification
. F" h' p D- w8 y" {. FHttp Service Specification, w& [( E7 d2 U3 @( P4 R$ [
Preference Service Specification
5 c2 u8 D d7 e! ]/ H& iWire Admin Service Specification
% C$ R8 F5 z5 l3 R8 i" sXML Parser Service Specification2 c: E: e- R2 u& g5 x, G
Metatype Specification
3 y8 W6 M& _- B7 z- HService Tracker Specification! J; n+ A$ F# {2 D( C1 a
Measurment and State Specification7 m( f. @# v, q! K% W, r
Position Specification
' x; J4 V* `* U5 cExecution Environment Specfication
) n1 J( V5 t$ X, I/ fOSGI Framework' z" @8 p. v B; R6 H) K
Framework是OSGI Service Platform规范的核心组成部分。它提供了一个通用的、安全可管理的Java framework。通过这个Framework可以支持一种叫做bundles的Service application的部署和扩展。( Q( m# ?0 n7 K
OSGI兼容设备可以下载并且安装OSGI bundles,也可一当他们不再需要的时候删除。bundles安装后会注册一定数量的Services,并被由同一个Framework下的其他bundles使用。
( z$ l" ~& m' ?2 U" h在一个动态扩展的的 OSGI环境中,Framework管理bundles的安装和更新。同时也管理bundles和Services之间的依赖关系。
; Q5 u/ W; ?/ P3 x3 aFramework提供给bundle开发者必须的资源来在Java平台上开发,为开发的bundles提供了代码动态加载的功能, 也使得开发者开发、部署一个大规模的Services变的很容易。
" I3 }+ l9 P& x# ?/ 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.3 ?' f5 G& s% x% h
一个一致的编程模型帮助开发者可以应付一些可估计的危急错误。Framework将会运行在不同的硬件环境上,但一致的接口确保软件组建可以运行在一致的服务接口上。
; _5 t: D* i- \: B, c# B0 vThe Bundle Object# O; {( Z9 \6 S ?; p4 h7 h
对于每一个安装在OSGI Service Platform的bundle都有一个与之关联的bundle object。一个bundle对象用来管理bundle的生命周期。这项工作通常由Management Agent来做。6 c% e& r: M: a4 p3 j2 y
Bundle State9 P& y& L# J% m7 K. |* x" C+ f4 g
bundle有以下状态;
3 |4 {0 r2 B9 z: fINSTALLED – The bundle has been successfully installed. Native code clauses must have been validated.
5 x+ Q" U8 w5 m' F+ ?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.
: t$ Q4 e- V5 [/ @4 k6 H% `# w, @" rSTARTING – The bundle is being started, and the BundleActivato r. start method has been called and has not yet returned.
& Y% s2 P: d8 K" O2 k. `- J, ySTOPPING – The bundle is being stopped, and the BundleActivato r. stop method has been called and has not yet returned.
/ r+ m. j2 u1 x7 R; E7 `% Y" _ACTIVE – The bundle has successfully started and is running.
: A+ |' z% T* E5 G3 CUNINSTALLED – The bundle has been uninstalled. It cannot move into another state.
D, @$ T" r7 z( T6 O7 A D4 Meclipse 3.0并没有用OSGI替换掉原来的PlugIn机制。它只是做了与标准兼容的工作:给用户提供了一系列的API来访问,在这个过程中,就必须要做一些改 变(比如plugin registry和loading机制)来同OSGI标准完全兼容。最初的Plugin核心只支持静态的扩展,就是说,如果要改变一个已经存在的Plug 就必须重启core,也就是要退出Eclipse并重启。; H( N) H2 a4 A; N& r0 ?1 n' V$ P
有很多人问Eclipse为什么要兼容OSGI规范而不是其他的规范呢?. p* j% S4 ~4 P D2 M
在 Eclipse被捐赠出来以前,Eclipse由OTI来开发,其目标是开发一个嵌入式Java软件的开发平台。互联网上现在仍然由很多的连接指向 Visual Age Micro Edition (VAME). 这也是SWT被构思的一个原因,他们想将SWT使用在嵌入式设备中的用户界面。这种渊源关系解释了当时为什么选择OSGI规范。7 i) l( U! J% w/ f* Z% N# u1 E. Y6 Y
另外一个原因是除了OSGI没有其他的规范。OSGI规范在轻量级服务架构应用方面被广泛的支持。而且OSGI被好多电信业的知名公司和一些其他行业的知名公司所支持。他们需要使用OSGI来同Sun的J2ME来抗衡。 |
|