 鲜花( 0)  鸡蛋( 0)
|
OSGi是Open Service Gateway Initiative的简称,该组织建立于1999年,是一个非赢利机构,旨在建立一个开放的服务规范,为通过网络向设备提供服务建立开放的标准。* `0 E5 g$ E; B. ?
OSGI 规范包括了构建开放的可交付网络服务的各方面,OSGI规范又包括了以下子规范。
/ {+ I% s$ J! E+ E( oFramework规范(OSGI核心,提供一个安全的可管理的Java Framework来部署可扩展的Java服务。)
, d; x3 b# o; O& @! o( Q! rPackage Admin Service规范(来管理不同的Bundle之间的引用关系。当Bundle更新或者反安装时判断是否有其他的服务正在使用当前的Bundle)( h7 I6 E8 Q8 S
Start Level规范(定义了启动和停止一个OSGi Service Platform时,不同的Bundles的启动或者停止的先后顺序)0 C4 F% r7 _3 o; o. r* q6 q; [
Permission Admin Service规范(Bundle是否许可执行另外的Bundle的代码)
2 T9 `- g4 m2 ^URL Handlers Service规范(怎样注册URL Schema,如何将java.io.InputStream对象转换为特定的Java对象). p2 B, J5 _$ g0 f& z) m) M
Log Service规范 (以下略。。。)- P' }5 a/ I" b0 E3 T6 P% ~' F, \: C
Configuration Admin Service规范0 ? q- B( u m- |
Device Access Specification9 U# z: M/ B2 p2 e
User Admin Service Specification
4 M2 x# X# E# b$ V& yIO Connector Service Specification" ?9 Z+ Z7 z) ?
Http Service Specification5 h6 m) }% }. `1 H# L+ }/ x* o
Preference Service Specification. l0 u0 b" _* l) Z5 v' \# V
Wire Admin Service Specification7 {- s- x, ^' C+ Z' ^' J
XML Parser Service Specification# ]& x8 M9 a) e% y
Metatype Specification
S! D2 |% I6 s# z2 xService Tracker Specification
8 U* G) V" L' J$ cMeasurment and State Specification/ R1 [* N' _% E* L7 g5 V
Position Specification
+ ?* y5 z2 X: f) C+ o9 QExecution Environment Specfication
" Q& i, P( F- I; B. a( }# Z3 _OSGI Framework
8 K y8 [9 A5 P( V# `2 {Framework是OSGI Service Platform规范的核心组成部分。它提供了一个通用的、安全可管理的Java framework。通过这个Framework可以支持一种叫做bundles的Service application的部署和扩展。0 c6 a: i h6 U7 t! [$ W y
OSGI兼容设备可以下载并且安装OSGI bundles,也可一当他们不再需要的时候删除。bundles安装后会注册一定数量的Services,并被由同一个Framework下的其他bundles使用。3 h+ t; P4 g* m5 q# n7 U
在一个动态扩展的的 OSGI环境中,Framework管理bundles的安装和更新。同时也管理bundles和Services之间的依赖关系。/ D3 \1 m6 j. V$ S
Framework提供给bundle开发者必须的资源来在Java平台上开发,为开发的bundles提供了代码动态加载的功能, 也使得开发者开发、部署一个大规模的Services变的很容易。
8 [0 r2 Q7 |* K6 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.3 o8 h5 Y5 Q7 T W* z1 ~5 A
一个一致的编程模型帮助开发者可以应付一些可估计的危急错误。Framework将会运行在不同的硬件环境上,但一致的接口确保软件组建可以运行在一致的服务接口上。! T0 P4 D3 e: d% f% \ _
The Bundle Object1 {- a) l& I/ f0 Q2 T+ ]
对于每一个安装在OSGI Service Platform的bundle都有一个与之关联的bundle object。一个bundle对象用来管理bundle的生命周期。这项工作通常由Management Agent来做。
0 D3 r' B$ h/ zBundle State
5 Y+ a0 T) P4 s/ @4 ^$ t- H1 `3 K _bundle有以下状态;
0 t, O! B0 @, ZINSTALLED – The bundle has been successfully installed. Native code clauses must have been validated.: |* i/ Y8 q* {, u
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.
, A1 B$ P; e3 U& {6 cSTARTING – The bundle is being started, and the BundleActivato r. start method has been called and has not yet returned.
, V9 |- D0 X) j* ~/ Z. c& ASTOPPING – The bundle is being stopped, and the BundleActivato r. stop method has been called and has not yet returned.! u, G8 Y( d) U! V5 v- A/ z
ACTIVE – The bundle has successfully started and is running.
2 R6 D a- Z$ k6 ?9 \) M( NUNINSTALLED – The bundle has been uninstalled. It cannot move into another state.. \1 ]4 G" J$ K' V0 I5 q* }
eclipse 3.0并没有用OSGI替换掉原来的PlugIn机制。它只是做了与标准兼容的工作:给用户提供了一系列的API来访问,在这个过程中,就必须要做一些改 变(比如plugin registry和loading机制)来同OSGI标准完全兼容。最初的Plugin核心只支持静态的扩展,就是说,如果要改变一个已经存在的Plug 就必须重启core,也就是要退出Eclipse并重启。
* J3 _( V H/ O. v* [2 ~/ `. G9 v有很多人问Eclipse为什么要兼容OSGI规范而不是其他的规范呢?7 k" g, h" j& i" b* B0 p
在 Eclipse被捐赠出来以前,Eclipse由OTI来开发,其目标是开发一个嵌入式Java软件的开发平台。互联网上现在仍然由很多的连接指向 Visual Age Micro Edition (VAME). 这也是SWT被构思的一个原因,他们想将SWT使用在嵌入式设备中的用户界面。这种渊源关系解释了当时为什么选择OSGI规范。% H% W4 j0 d& Z# t# z- K! p
另外一个原因是除了OSGI没有其他的规范。OSGI规范在轻量级服务架构应用方面被广泛的支持。而且OSGI被好多电信业的知名公司和一些其他行业的知名公司所支持。他们需要使用OSGI来同Sun的J2ME来抗衡。 |
|