 鲜花( 0)  鸡蛋( 0)
|
OSGi是Open Service Gateway Initiative的简称,该组织建立于1999年,是一个非赢利机构,旨在建立一个开放的服务规范,为通过网络向设备提供服务建立开放的标准。+ {, L/ E9 T0 ^5 b$ d/ [
OSGI 规范包括了构建开放的可交付网络服务的各方面,OSGI规范又包括了以下子规范。
T6 D7 O" {, I$ y: GFramework规范(OSGI核心,提供一个安全的可管理的Java Framework来部署可扩展的Java服务。)
, m: i' ~( N( g# z: h: X9 iPackage Admin Service规范(来管理不同的Bundle之间的引用关系。当Bundle更新或者反安装时判断是否有其他的服务正在使用当前的Bundle)' ~) Y8 }/ o/ H; v4 }% _1 P
Start Level规范(定义了启动和停止一个OSGi Service Platform时,不同的Bundles的启动或者停止的先后顺序)6 ~8 C- }7 W. G9 P. Q" \% Z) k
Permission Admin Service规范(Bundle是否许可执行另外的Bundle的代码)
) X- V, G# e+ yURL Handlers Service规范(怎样注册URL Schema,如何将java.io.InputStream对象转换为特定的Java对象)* v2 E4 P9 _- t" r( M% V
Log Service规范 (以下略。。。)+ ~" V/ N' d A& K G& m6 e
Configuration Admin Service规范$ M- G5 m* ~, g( T
Device Access Specification8 g6 ?) I: P) \* h
User Admin Service Specification
* _& R0 P( p! |$ J4 @IO Connector Service Specification
! u% O) F2 `. U, ~; Q, \Http Service Specification
) J9 E. k+ t& [! a7 r2 CPreference Service Specification
" e$ h% W+ q; O7 bWire Admin Service Specification
, x' [ a# r7 j1 F0 I nXML Parser Service Specification
. }3 s/ ]2 x* n5 p/ WMetatype Specification; P1 z e: g7 b: b0 A$ ?
Service Tracker Specification
! b( M7 c% c5 j- ?5 b9 sMeasurment and State Specification
9 I" R4 G! x1 Z6 K& i1 {Position Specification% Z1 t1 o# X3 ~/ s! e: |2 `
Execution Environment Specfication. i4 Q2 W+ B7 Y5 E: T1 |$ o% w% m C
OSGI Framework
# S; l, H% `3 S+ O% MFramework是OSGI Service Platform规范的核心组成部分。它提供了一个通用的、安全可管理的Java framework。通过这个Framework可以支持一种叫做bundles的Service application的部署和扩展。
! b! _" s7 P/ K; gOSGI兼容设备可以下载并且安装OSGI bundles,也可一当他们不再需要的时候删除。bundles安装后会注册一定数量的Services,并被由同一个Framework下的其他bundles使用。2 K8 r2 Y" A' {( B. s6 F N
在一个动态扩展的的 OSGI环境中,Framework管理bundles的安装和更新。同时也管理bundles和Services之间的依赖关系。
2 {- T- f5 G4 WFramework提供给bundle开发者必须的资源来在Java平台上开发,为开发的bundles提供了代码动态加载的功能, 也使得开发者开发、部署一个大规模的Services变的很容易。, n, h; E* b+ y
其 次,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.! k( Q2 V) k: s: m
一个一致的编程模型帮助开发者可以应付一些可估计的危急错误。Framework将会运行在不同的硬件环境上,但一致的接口确保软件组建可以运行在一致的服务接口上。8 E+ \: a7 v0 R
The Bundle Object
* ~9 y8 G9 S* [对于每一个安装在OSGI Service Platform的bundle都有一个与之关联的bundle object。一个bundle对象用来管理bundle的生命周期。这项工作通常由Management Agent来做。6 h' Z. y- S1 C! |9 U+ l7 G! v
Bundle State
! R( U' v8 j C% K. a$ r; n2 vbundle有以下状态;! S f7 i+ u/ p0 a9 v- E
INSTALLED – The bundle has been successfully installed. Native code clauses must have been validated.. ?# i _$ G4 f- |& y
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 {' m, \) V! \7 j/ U- \2 ^
STARTING – The bundle is being started, and the BundleActivato r. start method has been called and has not yet returned.8 f+ W" |" w2 L: o, m
STOPPING – The bundle is being stopped, and the BundleActivato r. stop method has been called and has not yet returned./ p2 Q1 [# [& B. Y
ACTIVE – The bundle has successfully started and is running. h1 W$ R$ M& a1 I( }0 P/ P/ l, ^
UNINSTALLED – The bundle has been uninstalled. It cannot move into another state.
6 e$ [* a/ t$ m+ U. D/ Reclipse 3.0并没有用OSGI替换掉原来的PlugIn机制。它只是做了与标准兼容的工作:给用户提供了一系列的API来访问,在这个过程中,就必须要做一些改 变(比如plugin registry和loading机制)来同OSGI标准完全兼容。最初的Plugin核心只支持静态的扩展,就是说,如果要改变一个已经存在的Plug 就必须重启core,也就是要退出Eclipse并重启。
3 R0 s& _1 F, _6 }, z* J# m有很多人问Eclipse为什么要兼容OSGI规范而不是其他的规范呢?
5 r* g) l7 h1 \* z4 ]2 L& w7 ^- d在 Eclipse被捐赠出来以前,Eclipse由OTI来开发,其目标是开发一个嵌入式Java软件的开发平台。互联网上现在仍然由很多的连接指向 Visual Age Micro Edition (VAME). 这也是SWT被构思的一个原因,他们想将SWT使用在嵌入式设备中的用户界面。这种渊源关系解释了当时为什么选择OSGI规范。- N8 Y# ?% T3 D; d e* l$ N
另外一个原因是除了OSGI没有其他的规范。OSGI规范在轻量级服务架构应用方面被广泛的支持。而且OSGI被好多电信业的知名公司和一些其他行业的知名公司所支持。他们需要使用OSGI来同Sun的J2ME来抗衡。 |
|