 鲜花( 0)  鸡蛋( 0)
|
OSGi是Open Service Gateway Initiative的简称,该组织建立于1999年,是一个非赢利机构,旨在建立一个开放的服务规范,为通过网络向设备提供服务建立开放的标准。
, z1 z) ~ W# ]7 L/ Y3 COSGI 规范包括了构建开放的可交付网络服务的各方面,OSGI规范又包括了以下子规范。
7 b) v$ k3 U. [: R" R! W& i! @Framework规范(OSGI核心,提供一个安全的可管理的Java Framework来部署可扩展的Java服务。) * k9 v* e3 u5 X& J+ ]1 H P/ B
Package Admin Service规范(来管理不同的Bundle之间的引用关系。当Bundle更新或者反安装时判断是否有其他的服务正在使用当前的Bundle)
% A- x; @- G0 \Start Level规范(定义了启动和停止一个OSGi Service Platform时,不同的Bundles的启动或者停止的先后顺序)
9 Z( y7 P, I1 GPermission Admin Service规范(Bundle是否许可执行另外的Bundle的代码)& @9 a' q2 J+ y) m5 ~+ _' O5 p# C
URL Handlers Service规范(怎样注册URL Schema,如何将java.io.InputStream对象转换为特定的Java对象)
* z5 e8 R) K3 T2 qLog Service规范 (以下略。。。)
& x+ C. [ L2 D/ ]2 m8 K: ^& YConfiguration Admin Service规范
9 f4 h9 f% V+ t# b. g! GDevice Access Specification
, i; ~: r* w" fUser Admin Service Specification
i4 O3 @, ?" Z5 j) O1 n; v& `IO Connector Service Specification
P( ~/ ~5 { Z0 _' M/ Y W! i$ u cHttp Service Specification" ^4 ?; A* D! F9 i5 u \4 Z
Preference Service Specification
. l- D5 i7 F5 _ MWire Admin Service Specification, p$ w, U! e K6 G! T2 G
XML Parser Service Specification
" c. R; t8 w" V, L' tMetatype Specification" B+ W4 N) H1 p$ y) T6 D9 y. e1 s0 u
Service Tracker Specification
1 f" `3 E% R, ~3 N# TMeasurment and State Specification- ~4 T6 t+ p; J" c8 D
Position Specification+ g$ ~; C# V. p! |6 R0 _
Execution Environment Specfication. A3 t5 k* D: B0 g! B' M( X: x
OSGI Framework
$ v+ a$ [9 ~/ b4 j" `( g) F) R9 IFramework是OSGI Service Platform规范的核心组成部分。它提供了一个通用的、安全可管理的Java framework。通过这个Framework可以支持一种叫做bundles的Service application的部署和扩展。
7 ^4 U/ u- X( f3 R. k) G+ ?5 F3 KOSGI兼容设备可以下载并且安装OSGI bundles,也可一当他们不再需要的时候删除。bundles安装后会注册一定数量的Services,并被由同一个Framework下的其他bundles使用。
; L# h5 ?% W; F% N# w在一个动态扩展的的 OSGI环境中,Framework管理bundles的安装和更新。同时也管理bundles和Services之间的依赖关系。
. P+ |, s# _" d: _Framework提供给bundle开发者必须的资源来在Java平台上开发,为开发的bundles提供了代码动态加载的功能, 也使得开发者开发、部署一个大规模的Services变的很容易。
- a; [; J$ d/ [5 F! Z3 _其 次,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.$ E3 v* w, C O
一个一致的编程模型帮助开发者可以应付一些可估计的危急错误。Framework将会运行在不同的硬件环境上,但一致的接口确保软件组建可以运行在一致的服务接口上。
2 H$ q. Z9 K+ y5 @& F5 jThe Bundle Object+ h% N, q9 _' h& g( T# m- z
对于每一个安装在OSGI Service Platform的bundle都有一个与之关联的bundle object。一个bundle对象用来管理bundle的生命周期。这项工作通常由Management Agent来做。0 x5 o* f( ?! g. ]& H
Bundle State3 V- j/ M/ }( j2 J# [ n0 p8 Y
bundle有以下状态;
" B4 T2 u* e$ y Y+ E5 u+ D' t9 m) vINSTALLED – The bundle has been successfully installed. Native code clauses must have been validated.6 F6 U- H- U+ t# b& v
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.
0 U6 H, \' O) n2 }8 h% p' d" S1 m* oSTARTING – The bundle is being started, and the BundleActivato r. start method has been called and has not yet returned.
( O' |" r$ j& Q% c+ ZSTOPPING – The bundle is being stopped, and the BundleActivato r. stop method has been called and has not yet returned.
/ I0 u! n p# q! xACTIVE – The bundle has successfully started and is running. x1 v- A: l, _' c6 f& B
UNINSTALLED – The bundle has been uninstalled. It cannot move into another state.
& g! O: Q- |) W% B! oeclipse 3.0并没有用OSGI替换掉原来的PlugIn机制。它只是做了与标准兼容的工作:给用户提供了一系列的API来访问,在这个过程中,就必须要做一些改 变(比如plugin registry和loading机制)来同OSGI标准完全兼容。最初的Plugin核心只支持静态的扩展,就是说,如果要改变一个已经存在的Plug 就必须重启core,也就是要退出Eclipse并重启。
$ U. h2 N* v: X) Y" s有很多人问Eclipse为什么要兼容OSGI规范而不是其他的规范呢?: m9 h7 N6 q. k0 W' k# z
在 Eclipse被捐赠出来以前,Eclipse由OTI来开发,其目标是开发一个嵌入式Java软件的开发平台。互联网上现在仍然由很多的连接指向 Visual Age Micro Edition (VAME). 这也是SWT被构思的一个原因,他们想将SWT使用在嵌入式设备中的用户界面。这种渊源关系解释了当时为什么选择OSGI规范。) Y) D* v. _6 n6 t$ `9 o W
另外一个原因是除了OSGI没有其他的规范。OSGI规范在轻量级服务架构应用方面被广泛的支持。而且OSGI被好多电信业的知名公司和一些其他行业的知名公司所支持。他们需要使用OSGI来同Sun的J2ME来抗衡。 |
|