 鲜花( 0)  鸡蛋( 0)
|
OSGi是Open Service Gateway Initiative的简称,该组织建立于1999年,是一个非赢利机构,旨在建立一个开放的服务规范,为通过网络向设备提供服务建立开放的标准。
3 {& @% c! z/ j- g1 COSGI 规范包括了构建开放的可交付网络服务的各方面,OSGI规范又包括了以下子规范。
$ R% U% f1 v! e9 k/ ~; v9 FFramework规范(OSGI核心,提供一个安全的可管理的Java Framework来部署可扩展的Java服务。)
3 i+ e0 j. Z N; l5 M3 VPackage Admin Service规范(来管理不同的Bundle之间的引用关系。当Bundle更新或者反安装时判断是否有其他的服务正在使用当前的Bundle)
5 t6 z, P# z. C, HStart Level规范(定义了启动和停止一个OSGi Service Platform时,不同的Bundles的启动或者停止的先后顺序)" ~. }5 \7 L' i$ y5 I
Permission Admin Service规范(Bundle是否许可执行另外的Bundle的代码)
; G# l/ m8 q: i1 Z$ z A$ p' N: r) ~URL Handlers Service规范(怎样注册URL Schema,如何将java.io.InputStream对象转换为特定的Java对象)
! v; I7 Y+ X6 e7 f8 H: ]+ E* aLog Service规范 (以下略。。。)
8 X% Y2 C+ y; M" [, c1 `" pConfiguration Admin Service规范
+ W8 g, i) g: q2 `" M! b6 E" SDevice Access Specification
( g2 ^1 B( x. i0 Q5 k2 S$ sUser Admin Service Specification
+ G4 C% X4 H9 S- j% P, F, FIO Connector Service Specification
0 W8 c# ~. {9 d/ Z9 W0 ^! RHttp Service Specification# ~8 u, }' S2 T
Preference Service Specification
# T' z9 H0 T4 Q' xWire Admin Service Specification2 e0 a9 d- i. \1 T# U* \" y
XML Parser Service Specification+ ]* d& H* k- i( t
Metatype Specification
+ h! i& g4 }1 T, w1 K) c; j1 e( xService Tracker Specification
- J) J( _- o0 V' `& t0 |# lMeasurment and State Specification
3 o: h! l9 P# O) H+ T$ w: EPosition Specification
( `* j: S" o- s j' A _Execution Environment Specfication
% `+ ]6 C, a0 L4 e" ?2 c# O: VOSGI Framework
% `) Y. \9 ~8 U$ [6 ~: _8 |/ |Framework是OSGI Service Platform规范的核心组成部分。它提供了一个通用的、安全可管理的Java framework。通过这个Framework可以支持一种叫做bundles的Service application的部署和扩展。7 ?) Q/ O; S. N. S
OSGI兼容设备可以下载并且安装OSGI bundles,也可一当他们不再需要的时候删除。bundles安装后会注册一定数量的Services,并被由同一个Framework下的其他bundles使用。+ v& V) O7 E) G1 U7 H* W
在一个动态扩展的的 OSGI环境中,Framework管理bundles的安装和更新。同时也管理bundles和Services之间的依赖关系。6 ` K$ t# V5 I" c l: `7 O
Framework提供给bundle开发者必须的资源来在Java平台上开发,为开发的bundles提供了代码动态加载的功能, 也使得开发者开发、部署一个大规模的Services变的很容易。- h, g$ H; t7 U4 [. Z+ I
其 次,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.; R8 m" Y$ V! r
一个一致的编程模型帮助开发者可以应付一些可估计的危急错误。Framework将会运行在不同的硬件环境上,但一致的接口确保软件组建可以运行在一致的服务接口上。
. A1 O* _# R( O0 nThe Bundle Object/ p: ?0 M2 r! B) f g
对于每一个安装在OSGI Service Platform的bundle都有一个与之关联的bundle object。一个bundle对象用来管理bundle的生命周期。这项工作通常由Management Agent来做。
0 w4 a* f: a; m0 { {+ DBundle State( x* ~- I, y$ e! G4 j% M0 @' w
bundle有以下状态;" U" v. o$ i @
INSTALLED – The bundle has been successfully installed. Native code clauses must have been validated.! W4 t! d7 O Z" x- K0 T& F, S% j
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.( x9 ^- a2 I7 `0 d6 e) B7 \
STARTING – The bundle is being started, and the BundleActivato r. start method has been called and has not yet returned.
) k/ b# s7 y* d# nSTOPPING – The bundle is being stopped, and the BundleActivato r. stop method has been called and has not yet returned.- }. s; i- |# l. e; ?2 C
ACTIVE – The bundle has successfully started and is running.1 l7 G$ T9 C* g- H3 N2 f& v* \
UNINSTALLED – The bundle has been uninstalled. It cannot move into another state.
! `' Y0 k2 T" ~0 s; O: H+ `eclipse 3.0并没有用OSGI替换掉原来的PlugIn机制。它只是做了与标准兼容的工作:给用户提供了一系列的API来访问,在这个过程中,就必须要做一些改 变(比如plugin registry和loading机制)来同OSGI标准完全兼容。最初的Plugin核心只支持静态的扩展,就是说,如果要改变一个已经存在的Plug 就必须重启core,也就是要退出Eclipse并重启。
$ h* s9 p" S/ g" ?5 E" d有很多人问Eclipse为什么要兼容OSGI规范而不是其他的规范呢?# D4 R# n/ V7 H: o
在 Eclipse被捐赠出来以前,Eclipse由OTI来开发,其目标是开发一个嵌入式Java软件的开发平台。互联网上现在仍然由很多的连接指向 Visual Age Micro Edition (VAME). 这也是SWT被构思的一个原因,他们想将SWT使用在嵌入式设备中的用户界面。这种渊源关系解释了当时为什么选择OSGI规范。
3 c! X" R; p$ g9 r8 V. E1 v- W; @. i另外一个原因是除了OSGI没有其他的规范。OSGI规范在轻量级服务架构应用方面被广泛的支持。而且OSGI被好多电信业的知名公司和一些其他行业的知名公司所支持。他们需要使用OSGI来同Sun的J2ME来抗衡。 |
|