 鲜花( 0)  鸡蛋( 0)
|
OSGi是Open Service Gateway Initiative的简称,该组织建立于1999年,是一个非赢利机构,旨在建立一个开放的服务规范,为通过网络向设备提供服务建立开放的标准。5 |( m& t p3 U5 w8 N' A5 E
OSGI 规范包括了构建开放的可交付网络服务的各方面,OSGI规范又包括了以下子规范。
! _* Z0 f, W# _$ WFramework规范(OSGI核心,提供一个安全的可管理的Java Framework来部署可扩展的Java服务。)
9 Z0 n( W+ x# m' O0 PPackage Admin Service规范(来管理不同的Bundle之间的引用关系。当Bundle更新或者反安装时判断是否有其他的服务正在使用当前的Bundle)
; G' B- O( F+ l' ~) ^1 G$ tStart Level规范(定义了启动和停止一个OSGi Service Platform时,不同的Bundles的启动或者停止的先后顺序)5 M4 X' a8 {% I$ J; }
Permission Admin Service规范(Bundle是否许可执行另外的Bundle的代码)
. k4 I% F& W6 G. O# vURL Handlers Service规范(怎样注册URL Schema,如何将java.io.InputStream对象转换为特定的Java对象)
3 e) E: L1 U6 O: uLog Service规范 (以下略。。。)7 m( l1 T& M- I ^: c6 d
Configuration Admin Service规范
! O, Z3 y3 P# V5 n7 C5 ODevice Access Specification6 D: O7 j2 u7 f
User Admin Service Specification& v0 d$ j; F( A9 B
IO Connector Service Specification
& z3 ?9 p4 e! U" \( k7 VHttp Service Specification5 j* g, j$ N( C! e5 Z* r& s
Preference Service Specification; t8 y+ M3 \: m# Q) q
Wire Admin Service Specification2 T5 ~: l" g) E+ M
XML Parser Service Specification
' X: f; C! t5 I- w; y8 @# y1 tMetatype Specification
" @! V0 k1 @7 o4 g- ?4 S% ~Service Tracker Specification
, J0 c0 U+ f! H0 D/ b. ]2 m" I* v+ p9 I: ZMeasurment and State Specification
$ w D% y7 O" N6 ~6 t) C9 d" ^3 mPosition Specification
! [, i7 [2 N! j$ z/ gExecution Environment Specfication0 r$ \( k" q( {' i
OSGI Framework' ?1 Y( _: J, j$ P4 @8 c# R" C
Framework是OSGI Service Platform规范的核心组成部分。它提供了一个通用的、安全可管理的Java framework。通过这个Framework可以支持一种叫做bundles的Service application的部署和扩展。' K# p# R* J- x* E6 n
OSGI兼容设备可以下载并且安装OSGI bundles,也可一当他们不再需要的时候删除。bundles安装后会注册一定数量的Services,并被由同一个Framework下的其他bundles使用。3 A! \% v' R. Z% [
在一个动态扩展的的 OSGI环境中,Framework管理bundles的安装和更新。同时也管理bundles和Services之间的依赖关系。
/ I. g2 `& A( A9 p* ?$ RFramework提供给bundle开发者必须的资源来在Java平台上开发,为开发的bundles提供了代码动态加载的功能, 也使得开发者开发、部署一个大规模的Services变的很容易。; @0 E% l! V8 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.5 V6 x9 x! Y- ?: O5 e
一个一致的编程模型帮助开发者可以应付一些可估计的危急错误。Framework将会运行在不同的硬件环境上,但一致的接口确保软件组建可以运行在一致的服务接口上。
" u: } h! Y8 q& s: [4 m2 [$ M. x9 O4 YThe Bundle Object
q/ V% V1 x6 D, t' W, t对于每一个安装在OSGI Service Platform的bundle都有一个与之关联的bundle object。一个bundle对象用来管理bundle的生命周期。这项工作通常由Management Agent来做。
% F j& W/ }1 H+ K2 [Bundle State
! {% K. c' @, e$ sbundle有以下状态;
|8 e* X6 a; ^% U& l( d4 HINSTALLED – The bundle has been successfully installed. Native code clauses must have been validated.
; V- y- J" F) @9 {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.
2 J$ f/ b0 j4 o. _! e. n9 CSTARTING – The bundle is being started, and the BundleActivato r. start method has been called and has not yet returned.) i9 s5 H2 E. Y
STOPPING – The bundle is being stopped, and the BundleActivato r. stop method has been called and has not yet returned.
# H/ q' H/ F! g) @# R8 v3 }1 M4 KACTIVE – The bundle has successfully started and is running.9 f3 @" z! k( e! n) t
UNINSTALLED – The bundle has been uninstalled. It cannot move into another state.
2 ^5 N! d: ]& y+ Qeclipse 3.0并没有用OSGI替换掉原来的PlugIn机制。它只是做了与标准兼容的工作:给用户提供了一系列的API来访问,在这个过程中,就必须要做一些改 变(比如plugin registry和loading机制)来同OSGI标准完全兼容。最初的Plugin核心只支持静态的扩展,就是说,如果要改变一个已经存在的Plug 就必须重启core,也就是要退出Eclipse并重启。/ T; c9 W3 i0 l7 }
有很多人问Eclipse为什么要兼容OSGI规范而不是其他的规范呢?0 Z4 m% {0 t3 J1 w4 w: P$ i. S
在 Eclipse被捐赠出来以前,Eclipse由OTI来开发,其目标是开发一个嵌入式Java软件的开发平台。互联网上现在仍然由很多的连接指向 Visual Age Micro Edition (VAME). 这也是SWT被构思的一个原因,他们想将SWT使用在嵌入式设备中的用户界面。这种渊源关系解释了当时为什么选择OSGI规范。
$ J3 p0 r; _# x: s/ v另外一个原因是除了OSGI没有其他的规范。OSGI规范在轻量级服务架构应用方面被广泛的支持。而且OSGI被好多电信业的知名公司和一些其他行业的知名公司所支持。他们需要使用OSGI来同Sun的J2ME来抗衡。 |
|