 鲜花( 0)  鸡蛋( 0)
|
OSGi是Open Service Gateway Initiative的简称,该组织建立于1999年,是一个非赢利机构,旨在建立一个开放的服务规范,为通过网络向设备提供服务建立开放的标准。
1 n, }* v; j; N2 Q8 A+ A, G, S( Q0 JOSGI 规范包括了构建开放的可交付网络服务的各方面,OSGI规范又包括了以下子规范。
% {* G0 ?( T4 @! ]Framework规范(OSGI核心,提供一个安全的可管理的Java Framework来部署可扩展的Java服务。) 5 i& W6 w: ?( n7 d' M+ K B
Package Admin Service规范(来管理不同的Bundle之间的引用关系。当Bundle更新或者反安装时判断是否有其他的服务正在使用当前的Bundle)) T; C0 [7 C6 Q* u9 J& A. R
Start Level规范(定义了启动和停止一个OSGi Service Platform时,不同的Bundles的启动或者停止的先后顺序)
$ e* G/ J, `5 c! K0 }4 M6 JPermission Admin Service规范(Bundle是否许可执行另外的Bundle的代码)
# j. G1 {4 v* Y7 j9 E9 S" f0 LURL Handlers Service规范(怎样注册URL Schema,如何将java.io.InputStream对象转换为特定的Java对象)1 d0 |5 f$ z9 k7 w
Log Service规范 (以下略。。。)" V5 d" w x1 l# l; A
Configuration Admin Service规范
: [6 ?( O/ n4 v- oDevice Access Specification4 E6 G3 p/ R, |- U0 d8 H
User Admin Service Specification0 E+ n9 {* O4 `
IO Connector Service Specification) [2 S/ o v! ~: l% k P7 F8 j
Http Service Specification
6 o( d6 s1 p6 }+ `* MPreference Service Specification
% `0 F, S; V7 ` A" kWire Admin Service Specification
- f+ o7 a t$ i5 h) y8 \3 oXML Parser Service Specification! L3 I( `( z2 ~8 [' G- _
Metatype Specification; H* ]; U1 P$ G
Service Tracker Specification$ w3 C4 p6 o$ `% j
Measurment and State Specification
0 Z( i$ z& w# ZPosition Specification: i D2 P! b/ Z: }6 s" q
Execution Environment Specfication3 `7 c3 G; x0 X; V2 {
OSGI Framework
( R* Y, y6 ?) `+ c3 FFramework是OSGI Service Platform规范的核心组成部分。它提供了一个通用的、安全可管理的Java framework。通过这个Framework可以支持一种叫做bundles的Service application的部署和扩展。2 J; O4 L- Y* v: \! j
OSGI兼容设备可以下载并且安装OSGI bundles,也可一当他们不再需要的时候删除。bundles安装后会注册一定数量的Services,并被由同一个Framework下的其他bundles使用。2 L4 K: y+ x1 A( i
在一个动态扩展的的 OSGI环境中,Framework管理bundles的安装和更新。同时也管理bundles和Services之间的依赖关系。
0 a" b4 @* V1 Z3 g- Y) G2 GFramework提供给bundle开发者必须的资源来在Java平台上开发,为开发的bundles提供了代码动态加载的功能, 也使得开发者开发、部署一个大规模的Services变的很容易。% B: ? y n/ R' V2 b6 j/ [
其 次,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 S l$ ~, ~8 L. s7 H+ ?一个一致的编程模型帮助开发者可以应付一些可估计的危急错误。Framework将会运行在不同的硬件环境上,但一致的接口确保软件组建可以运行在一致的服务接口上。, A; ^4 Q$ h9 Y, q& i8 o
The Bundle Object
# @6 `. k( ]1 b* U% A2 k对于每一个安装在OSGI Service Platform的bundle都有一个与之关联的bundle object。一个bundle对象用来管理bundle的生命周期。这项工作通常由Management Agent来做。2 y* H4 k/ O b1 I+ m
Bundle State
# R+ ?9 D6 a2 U, M4 [) [bundle有以下状态;* x. s0 S, X8 T& q0 Y4 R8 @
INSTALLED – The bundle has been successfully installed. Native code clauses must have been validated.
% }) P* B/ Q( H/ t8 NRESOLVED – All Java classes that the bundle needs are available. This state indicates that the bundle is either ready to be started or has stopped.
1 X* o- Z- `5 x2 t5 a; H! bSTARTING – The bundle is being started, and the BundleActivato r. start method has been called and has not yet returned.2 [* R7 t) p, T1 ~1 Y# {; S
STOPPING – The bundle is being stopped, and the BundleActivato r. stop method has been called and has not yet returned.0 b1 \: k5 I0 Y, ?' b6 r
ACTIVE – The bundle has successfully started and is running.
# ?! v+ }8 p9 e0 p$ \; YUNINSTALLED – The bundle has been uninstalled. It cannot move into another state.8 ?, A! j& N6 a
eclipse 3.0并没有用OSGI替换掉原来的PlugIn机制。它只是做了与标准兼容的工作:给用户提供了一系列的API来访问,在这个过程中,就必须要做一些改 变(比如plugin registry和loading机制)来同OSGI标准完全兼容。最初的Plugin核心只支持静态的扩展,就是说,如果要改变一个已经存在的Plug 就必须重启core,也就是要退出Eclipse并重启。0 n( P; u3 n3 P0 p/ n$ ]2 f0 n
有很多人问Eclipse为什么要兼容OSGI规范而不是其他的规范呢?9 U! V/ k( q6 d/ g
在 Eclipse被捐赠出来以前,Eclipse由OTI来开发,其目标是开发一个嵌入式Java软件的开发平台。互联网上现在仍然由很多的连接指向 Visual Age Micro Edition (VAME). 这也是SWT被构思的一个原因,他们想将SWT使用在嵌入式设备中的用户界面。这种渊源关系解释了当时为什么选择OSGI规范。- y" k4 e6 {; a- ^8 j
另外一个原因是除了OSGI没有其他的规范。OSGI规范在轻量级服务架构应用方面被广泛的支持。而且OSGI被好多电信业的知名公司和一些其他行业的知名公司所支持。他们需要使用OSGI来同Sun的J2ME来抗衡。 |
|