 鲜花( 0)  鸡蛋( 0)
|
OSGi是Open Service Gateway Initiative的简称,该组织建立于1999年,是一个非赢利机构,旨在建立一个开放的服务规范,为通过网络向设备提供服务建立开放的标准。
6 f/ i4 q7 I4 @4 o! hOSGI 规范包括了构建开放的可交付网络服务的各方面,OSGI规范又包括了以下子规范。
8 S+ g+ n7 B. c( E' c; nFramework规范(OSGI核心,提供一个安全的可管理的Java Framework来部署可扩展的Java服务。)
& s! v& @/ T3 p1 z# @1 q4 z' CPackage Admin Service规范(来管理不同的Bundle之间的引用关系。当Bundle更新或者反安装时判断是否有其他的服务正在使用当前的Bundle)
% c$ e, [! b+ [3 dStart Level规范(定义了启动和停止一个OSGi Service Platform时,不同的Bundles的启动或者停止的先后顺序)
6 _, a4 M8 A- S; OPermission Admin Service规范(Bundle是否许可执行另外的Bundle的代码); u6 R" c7 s( @1 ~6 _6 ~
URL Handlers Service规范(怎样注册URL Schema,如何将java.io.InputStream对象转换为特定的Java对象)+ |" m. r6 m6 K. x8 `% n* b2 ]
Log Service规范 (以下略。。。)
J% y/ ?$ Q( b$ i5 D6 [9 F2 E$ ~5 ZConfiguration Admin Service规范4 u$ y" V, l6 U+ |+ `* x8 J& H
Device Access Specification1 P/ l7 z8 b1 ?; ]/ b$ I+ e
User Admin Service Specification$ M5 a9 w3 d8 ?0 K4 _! S, z$ x) G
IO Connector Service Specification& x- D% f" E( i# Z, s# y t
Http Service Specification
' I% T2 k) m8 Z+ M0 qPreference Service Specification
, w ~$ p5 [4 _0 wWire Admin Service Specification8 m5 S/ }5 `# N0 G
XML Parser Service Specification8 m! p/ X6 [9 v4 b: T5 g& g0 _! k
Metatype Specification5 W; m& S; }- \5 v u8 N' A
Service Tracker Specification7 i3 `0 G! @& p
Measurment and State Specification
1 C% a: S% G' P NPosition Specification& D2 C( s S+ ]( L4 ^& X; C# h
Execution Environment Specfication( u0 T) w% g% E
OSGI Framework/ k4 P2 e1 }& S6 z. s Y/ h0 T& X# o
Framework是OSGI Service Platform规范的核心组成部分。它提供了一个通用的、安全可管理的Java framework。通过这个Framework可以支持一种叫做bundles的Service application的部署和扩展。' r' ^, O y5 P/ @( Y2 ~5 Y3 V
OSGI兼容设备可以下载并且安装OSGI bundles,也可一当他们不再需要的时候删除。bundles安装后会注册一定数量的Services,并被由同一个Framework下的其他bundles使用。
7 b- G& ~" l" w' a! m7 f- M在一个动态扩展的的 OSGI环境中,Framework管理bundles的安装和更新。同时也管理bundles和Services之间的依赖关系。
s8 `2 b% R: L6 f) _" y% XFramework提供给bundle开发者必须的资源来在Java平台上开发,为开发的bundles提供了代码动态加载的功能, 也使得开发者开发、部署一个大规模的Services变的很容易。2 u! `; k7 D9 y4 G/ g, L; r8 S
其 次,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.* t* T* c% \7 V n
一个一致的编程模型帮助开发者可以应付一些可估计的危急错误。Framework将会运行在不同的硬件环境上,但一致的接口确保软件组建可以运行在一致的服务接口上。
3 v$ @# F8 [3 x3 W" eThe Bundle Object
0 {0 d3 p7 \/ _6 z: G对于每一个安装在OSGI Service Platform的bundle都有一个与之关联的bundle object。一个bundle对象用来管理bundle的生命周期。这项工作通常由Management Agent来做。
i3 O+ u. l3 `; I5 h% T" pBundle State' \' M1 L# \7 m% [
bundle有以下状态;3 ]1 O$ x" a4 ], [4 G+ M5 K
INSTALLED – The bundle has been successfully installed. Native code clauses must have been validated.$ F' f4 @2 u# S) ]( o) j: A' A p
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., q8 Q! n* }; c2 a! F0 ^) [
STARTING – The bundle is being started, and the BundleActivato r. start method has been called and has not yet returned.5 P" ^2 i9 K% \' e& y$ R8 L+ |
STOPPING – The bundle is being stopped, and the BundleActivato r. stop method has been called and has not yet returned.
. Z: f) F: V# X7 ^& L" X! DACTIVE – The bundle has successfully started and is running.& F1 B, h- g% f/ D: ^( v% y
UNINSTALLED – The bundle has been uninstalled. It cannot move into another state.
9 Q: \# C/ O$ K) X. V+ u; O6 i; s; ceclipse 3.0并没有用OSGI替换掉原来的PlugIn机制。它只是做了与标准兼容的工作:给用户提供了一系列的API来访问,在这个过程中,就必须要做一些改 变(比如plugin registry和loading机制)来同OSGI标准完全兼容。最初的Plugin核心只支持静态的扩展,就是说,如果要改变一个已经存在的Plug 就必须重启core,也就是要退出Eclipse并重启。
% ^% b: X9 g8 y' ` {. h有很多人问Eclipse为什么要兼容OSGI规范而不是其他的规范呢?4 Q; y2 i( e6 i
在 Eclipse被捐赠出来以前,Eclipse由OTI来开发,其目标是开发一个嵌入式Java软件的开发平台。互联网上现在仍然由很多的连接指向 Visual Age Micro Edition (VAME). 这也是SWT被构思的一个原因,他们想将SWT使用在嵌入式设备中的用户界面。这种渊源关系解释了当时为什么选择OSGI规范。
( {! O; ]8 F8 X0 r4 ~另外一个原因是除了OSGI没有其他的规范。OSGI规范在轻量级服务架构应用方面被广泛的支持。而且OSGI被好多电信业的知名公司和一些其他行业的知名公司所支持。他们需要使用OSGI来同Sun的J2ME来抗衡。 |
|