 鲜花( 0)  鸡蛋( 0)
|
OSGi是Open Service Gateway Initiative的简称,该组织建立于1999年,是一个非赢利机构,旨在建立一个开放的服务规范,为通过网络向设备提供服务建立开放的标准。' H/ B. i. Z0 X# e, a
OSGI 规范包括了构建开放的可交付网络服务的各方面,OSGI规范又包括了以下子规范。 . f6 O/ g$ h) q
Framework规范(OSGI核心,提供一个安全的可管理的Java Framework来部署可扩展的Java服务。) + Q; T2 Y- I8 c4 ~, d
Package Admin Service规范(来管理不同的Bundle之间的引用关系。当Bundle更新或者反安装时判断是否有其他的服务正在使用当前的Bundle)3 W2 E* x% L) Y3 {. H9 J! J. j
Start Level规范(定义了启动和停止一个OSGi Service Platform时,不同的Bundles的启动或者停止的先后顺序)& M3 E+ z( p) r! U3 D
Permission Admin Service规范(Bundle是否许可执行另外的Bundle的代码)! N8 _. Y; i% d" n; ^& ?4 ?8 J2 m
URL Handlers Service规范(怎样注册URL Schema,如何将java.io.InputStream对象转换为特定的Java对象)
5 l, r& a, V& N1 L5 iLog Service规范 (以下略。。。)
& n$ P6 E4 T& S1 CConfiguration Admin Service规范
T( F2 R8 `' a) S* R& VDevice Access Specification/ X4 v0 ~/ i: Z, G0 b3 c8 c% V2 [
User Admin Service Specification
0 a0 R0 o2 P- \* Y V5 `) h# w+ F3 VIO Connector Service Specification
2 f( [! Q9 i- V3 L- ZHttp Service Specification2 D' K1 | ]1 o" R" O7 K
Preference Service Specification
$ k0 m% P! ?$ d7 g1 w3 ~- g- HWire Admin Service Specification
# ]3 \8 L& j9 Q% JXML Parser Service Specification4 f* }/ G) Z* t$ G" `
Metatype Specification1 j; g% Y( @9 Y) k+ L2 P
Service Tracker Specification
" x8 P- W; h+ X# d- }& c7 y1 yMeasurment and State Specification
* N9 O& h* o: S# aPosition Specification/ K1 @3 d' y& A1 k3 Q6 C2 y
Execution Environment Specfication6 _2 d# @. k0 f1 g
OSGI Framework
@% q' L+ o1 o! }Framework是OSGI Service Platform规范的核心组成部分。它提供了一个通用的、安全可管理的Java framework。通过这个Framework可以支持一种叫做bundles的Service application的部署和扩展。
H% e; A5 t# A, I' g! p3 LOSGI兼容设备可以下载并且安装OSGI bundles,也可一当他们不再需要的时候删除。bundles安装后会注册一定数量的Services,并被由同一个Framework下的其他bundles使用。: `2 B2 U5 E" @ D* Y$ N/ |
在一个动态扩展的的 OSGI环境中,Framework管理bundles的安装和更新。同时也管理bundles和Services之间的依赖关系。- z5 S! l5 Z: E1 {9 ?2 m5 [: I
Framework提供给bundle开发者必须的资源来在Java平台上开发,为开发的bundles提供了代码动态加载的功能, 也使得开发者开发、部署一个大规模的Services变的很容易。0 \2 |) m$ ?- m9 u n
其 次,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.8 h# L$ Y* H, G. O k5 [
一个一致的编程模型帮助开发者可以应付一些可估计的危急错误。Framework将会运行在不同的硬件环境上,但一致的接口确保软件组建可以运行在一致的服务接口上。6 o. a q x/ v- i4 K& z- P' B5 F
The Bundle Object
! z8 V$ F+ i" s D4 v3 M对于每一个安装在OSGI Service Platform的bundle都有一个与之关联的bundle object。一个bundle对象用来管理bundle的生命周期。这项工作通常由Management Agent来做。
0 g* A f+ k5 uBundle State( d m, M) x y' m4 ?2 d" J- K
bundle有以下状态;
f \* M& c% V+ b$ ^5 gINSTALLED – The bundle has been successfully installed. Native code clauses must have been validated.
/ c8 i G: y5 r6 a+ YRESOLVED – 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 ^9 f& T! `8 H& r2 h
STARTING – The bundle is being started, and the BundleActivato r. start method has been called and has not yet returned.1 Y+ Y) p2 ?% T9 p1 C$ d! I
STOPPING – The bundle is being stopped, and the BundleActivato r. stop method has been called and has not yet returned.
4 O0 Z, Z* j# ]/ y* E4 a- O6 N7 bACTIVE – The bundle has successfully started and is running.$ c6 J: U9 [: k, P7 F
UNINSTALLED – The bundle has been uninstalled. It cannot move into another state.
) R/ i g+ a6 {! }: s+ Weclipse 3.0并没有用OSGI替换掉原来的PlugIn机制。它只是做了与标准兼容的工作:给用户提供了一系列的API来访问,在这个过程中,就必须要做一些改 变(比如plugin registry和loading机制)来同OSGI标准完全兼容。最初的Plugin核心只支持静态的扩展,就是说,如果要改变一个已经存在的Plug 就必须重启core,也就是要退出Eclipse并重启。
" e) J# h! U1 W' p有很多人问Eclipse为什么要兼容OSGI规范而不是其他的规范呢?; N: r, L5 J) g! f& _
在 Eclipse被捐赠出来以前,Eclipse由OTI来开发,其目标是开发一个嵌入式Java软件的开发平台。互联网上现在仍然由很多的连接指向 Visual Age Micro Edition (VAME). 这也是SWT被构思的一个原因,他们想将SWT使用在嵌入式设备中的用户界面。这种渊源关系解释了当时为什么选择OSGI规范。* c& }3 c. r# b
另外一个原因是除了OSGI没有其他的规范。OSGI规范在轻量级服务架构应用方面被广泛的支持。而且OSGI被好多电信业的知名公司和一些其他行业的知名公司所支持。他们需要使用OSGI来同Sun的J2ME来抗衡。 |
|