 鲜花( 0)  鸡蛋( 0)
|
OSGi是Open Service Gateway Initiative的简称,该组织建立于1999年,是一个非赢利机构,旨在建立一个开放的服务规范,为通过网络向设备提供服务建立开放的标准。
! Z5 U1 O4 D$ C! U! z' S+ BOSGI 规范包括了构建开放的可交付网络服务的各方面,OSGI规范又包括了以下子规范。
2 }5 m" W: e9 U/ XFramework规范(OSGI核心,提供一个安全的可管理的Java Framework来部署可扩展的Java服务。)
2 [6 f S( f( f& ^) ZPackage Admin Service规范(来管理不同的Bundle之间的引用关系。当Bundle更新或者反安装时判断是否有其他的服务正在使用当前的Bundle)
; |7 o, P1 P3 {4 o1 O8 H; Z4 s; SStart Level规范(定义了启动和停止一个OSGi Service Platform时,不同的Bundles的启动或者停止的先后顺序)
) G- g+ a3 S4 X! P5 `Permission Admin Service规范(Bundle是否许可执行另外的Bundle的代码)8 T% j3 t2 J2 p& p
URL Handlers Service规范(怎样注册URL Schema,如何将java.io.InputStream对象转换为特定的Java对象)
" P1 o8 V$ E0 v" [% M2 oLog Service规范 (以下略。。。)
: F0 y' A, F9 U2 sConfiguration Admin Service规范
! ?% z7 s2 m. }6 r3 vDevice Access Specification
6 _4 M- k0 I; K% H5 c3 NUser Admin Service Specification
7 P) n# M" C& V$ @3 |8 jIO Connector Service Specification
. h5 {/ Z; ]! J2 y0 |/ A% ZHttp Service Specification
7 b3 g; r4 n) V) ?1 ?% uPreference Service Specification9 d' k7 |& S, b/ l5 _" n
Wire Admin Service Specification
2 S# E5 T, W- c3 \0 U2 h; g; d( xXML Parser Service Specification
4 x2 h0 Y) }/ R4 b7 JMetatype Specification
% K4 g* c t9 s5 T9 zService Tracker Specification1 N2 Y; Z( U% U5 T+ y; y% h
Measurment and State Specification
" l' f# o$ x4 x e: o7 I' \9 UPosition Specification$ J) x3 \" f, `. ]4 Z9 D. R' E3 a
Execution Environment Specfication
& n3 O @8 \# l) H4 k- D, KOSGI Framework4 i) X- ?: Y( z7 l, T. q) n* r- g& I
Framework是OSGI Service Platform规范的核心组成部分。它提供了一个通用的、安全可管理的Java framework。通过这个Framework可以支持一种叫做bundles的Service application的部署和扩展。9 X/ E% L7 d: _; F% O
OSGI兼容设备可以下载并且安装OSGI bundles,也可一当他们不再需要的时候删除。bundles安装后会注册一定数量的Services,并被由同一个Framework下的其他bundles使用。
* @& K- n: R) H' i. k在一个动态扩展的的 OSGI环境中,Framework管理bundles的安装和更新。同时也管理bundles和Services之间的依赖关系。* \4 M' ]) {) u3 ?" {
Framework提供给bundle开发者必须的资源来在Java平台上开发,为开发的bundles提供了代码动态加载的功能, 也使得开发者开发、部署一个大规模的Services变的很容易。! m- b5 S9 ^; G. r- G- s4 f3 z
其 次,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.2 U, \; y+ { q! T" R9 a- q$ g
一个一致的编程模型帮助开发者可以应付一些可估计的危急错误。Framework将会运行在不同的硬件环境上,但一致的接口确保软件组建可以运行在一致的服务接口上。
: V) _( l. h2 g; }The Bundle Object
7 c1 n2 f' o8 s: J" t对于每一个安装在OSGI Service Platform的bundle都有一个与之关联的bundle object。一个bundle对象用来管理bundle的生命周期。这项工作通常由Management Agent来做。- F! D1 r! H5 q Y
Bundle State
& ~: H$ ]1 t5 O* N, p' g" ~* nbundle有以下状态;1 a8 t4 N- L* g+ p9 p
INSTALLED – The bundle has been successfully installed. Native code clauses must have been validated.
9 S1 b$ o: n7 f5 Y' b8 l# c! w: h' X& Q5 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. R% t! |. L& ~& y
STARTING – The bundle is being started, and the BundleActivato r. start method has been called and has not yet returned.
! R; I' a$ M8 g2 eSTOPPING – The bundle is being stopped, and the BundleActivato r. stop method has been called and has not yet returned.) }; _; w5 p1 O
ACTIVE – The bundle has successfully started and is running.
1 j' r( q) w- a- D h: \+ mUNINSTALLED – The bundle has been uninstalled. It cannot move into another state.
% t! A5 {8 |2 g5 Oeclipse 3.0并没有用OSGI替换掉原来的PlugIn机制。它只是做了与标准兼容的工作:给用户提供了一系列的API来访问,在这个过程中,就必须要做一些改 变(比如plugin registry和loading机制)来同OSGI标准完全兼容。最初的Plugin核心只支持静态的扩展,就是说,如果要改变一个已经存在的Plug 就必须重启core,也就是要退出Eclipse并重启。: @0 r! x7 O* x; k# ~4 A9 s+ [
有很多人问Eclipse为什么要兼容OSGI规范而不是其他的规范呢?% ]' A6 ^. Y7 W# r. R M0 ]
在 Eclipse被捐赠出来以前,Eclipse由OTI来开发,其目标是开发一个嵌入式Java软件的开发平台。互联网上现在仍然由很多的连接指向 Visual Age Micro Edition (VAME). 这也是SWT被构思的一个原因,他们想将SWT使用在嵌入式设备中的用户界面。这种渊源关系解释了当时为什么选择OSGI规范。
0 \ q5 l% [! X P) ?另外一个原因是除了OSGI没有其他的规范。OSGI规范在轻量级服务架构应用方面被广泛的支持。而且OSGI被好多电信业的知名公司和一些其他行业的知名公司所支持。他们需要使用OSGI来同Sun的J2ME来抗衡。 |
|