 鲜花( 0)  鸡蛋( 0)
|
OSGi是Open Service Gateway Initiative的简称,该组织建立于1999年,是一个非赢利机构,旨在建立一个开放的服务规范,为通过网络向设备提供服务建立开放的标准。
2 [: C! h9 @" E8 B/ N& ^5 U/ A1 d+ zOSGI 规范包括了构建开放的可交付网络服务的各方面,OSGI规范又包括了以下子规范。
4 {2 M/ Q4 C0 iFramework规范(OSGI核心,提供一个安全的可管理的Java Framework来部署可扩展的Java服务。)
- P1 g1 a7 y3 E2 n2 n0 `' u& V7 cPackage Admin Service规范(来管理不同的Bundle之间的引用关系。当Bundle更新或者反安装时判断是否有其他的服务正在使用当前的Bundle)9 v, Y- A O a
Start Level规范(定义了启动和停止一个OSGi Service Platform时,不同的Bundles的启动或者停止的先后顺序)
6 n; m: X# T- i3 g2 x' uPermission Admin Service规范(Bundle是否许可执行另外的Bundle的代码)
$ T# @1 T B7 BURL Handlers Service规范(怎样注册URL Schema,如何将java.io.InputStream对象转换为特定的Java对象)
2 U* U- Z( y/ x7 yLog Service规范 (以下略。。。)
6 G; @0 |4 O' l) _1 C7 D* ]Configuration Admin Service规范: p" J$ s. {, g9 f+ @6 Q" i$ K
Device Access Specification
. q( c: W6 Q$ oUser Admin Service Specification6 J4 @& l+ E. F: ]( k' n! E- V
IO Connector Service Specification* r- e% ~7 Q7 z! x; d/ c! d* F
Http Service Specification
3 B( B9 H( `$ F4 ^5 b9 EPreference Service Specification/ P' g0 i8 A5 g9 _
Wire Admin Service Specification' L2 g* y, j+ a/ q. J6 z+ z4 v
XML Parser Service Specification8 V+ F+ f& S4 A+ y0 u1 {- ^/ a
Metatype Specification
+ |& D6 Y, x% N P e$ s4 }Service Tracker Specification0 J9 _4 B" k, H8 E C* z
Measurment and State Specification
7 |5 t* f3 B, e4 C& B a; v$ {Position Specification
( c7 n- ?7 Z3 k) C; y5 x+ XExecution Environment Specfication9 i+ x, K: y( n5 ^8 Z* M
OSGI Framework
9 C" L( y; }8 tFramework是OSGI Service Platform规范的核心组成部分。它提供了一个通用的、安全可管理的Java framework。通过这个Framework可以支持一种叫做bundles的Service application的部署和扩展。' _+ g# _ U+ @& x* S+ N
OSGI兼容设备可以下载并且安装OSGI bundles,也可一当他们不再需要的时候删除。bundles安装后会注册一定数量的Services,并被由同一个Framework下的其他bundles使用。
$ z; Y" w' a. x5 v5 e% n在一个动态扩展的的 OSGI环境中,Framework管理bundles的安装和更新。同时也管理bundles和Services之间的依赖关系。
' k2 i8 r( v0 `( {Framework提供给bundle开发者必须的资源来在Java平台上开发,为开发的bundles提供了代码动态加载的功能, 也使得开发者开发、部署一个大规模的Services变的很容易。
* ~; E4 {! P0 w其 次,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.7 G8 [: _* h" h( Q
一个一致的编程模型帮助开发者可以应付一些可估计的危急错误。Framework将会运行在不同的硬件环境上,但一致的接口确保软件组建可以运行在一致的服务接口上。
6 c1 n. K# S E7 e/ R% x9 uThe Bundle Object
" `7 h- c7 C; ^% r对于每一个安装在OSGI Service Platform的bundle都有一个与之关联的bundle object。一个bundle对象用来管理bundle的生命周期。这项工作通常由Management Agent来做。4 X, [% H% A, U; V# n$ B
Bundle State& ^7 y5 a! H# S, o. L
bundle有以下状态;3 C. ^. [: S; g) A1 U: v; w
INSTALLED – The bundle has been successfully installed. Native code clauses must have been validated.
2 F! }7 R; H7 Y# j; `8 PRESOLVED – All Java classes that the bundle needs are available. This state indicates that the bundle is either ready to be started or has stopped.
' m% r. \# r# mSTARTING – The bundle is being started, and the BundleActivato r. start method has been called and has not yet returned., L0 x0 M2 n: h, C
STOPPING – The bundle is being stopped, and the BundleActivato r. stop method has been called and has not yet returned.
8 Y( w1 c8 _$ t/ \& l; R* P! |5 nACTIVE – The bundle has successfully started and is running.
+ W9 @7 N$ @2 w& k4 TUNINSTALLED – The bundle has been uninstalled. It cannot move into another state., G5 w% U8 z& T5 D$ F4 [) b
eclipse 3.0并没有用OSGI替换掉原来的PlugIn机制。它只是做了与标准兼容的工作:给用户提供了一系列的API来访问,在这个过程中,就必须要做一些改 变(比如plugin registry和loading机制)来同OSGI标准完全兼容。最初的Plugin核心只支持静态的扩展,就是说,如果要改变一个已经存在的Plug 就必须重启core,也就是要退出Eclipse并重启。2 Q7 Q) y9 Z' m" |$ o' n5 l
有很多人问Eclipse为什么要兼容OSGI规范而不是其他的规范呢?" C; } I5 M( ^6 C, z3 v3 D! L
在 Eclipse被捐赠出来以前,Eclipse由OTI来开发,其目标是开发一个嵌入式Java软件的开发平台。互联网上现在仍然由很多的连接指向 Visual Age Micro Edition (VAME). 这也是SWT被构思的一个原因,他们想将SWT使用在嵌入式设备中的用户界面。这种渊源关系解释了当时为什么选择OSGI规范。! U5 G5 p3 J1 M; \6 f
另外一个原因是除了OSGI没有其他的规范。OSGI规范在轻量级服务架构应用方面被广泛的支持。而且OSGI被好多电信业的知名公司和一些其他行业的知名公司所支持。他们需要使用OSGI来同Sun的J2ME来抗衡。 |
|