 鲜花( 0)  鸡蛋( 0)
|
OSGi是Open Service Gateway Initiative的简称,该组织建立于1999年,是一个非赢利机构,旨在建立一个开放的服务规范,为通过网络向设备提供服务建立开放的标准。
! C' {% j9 M. ^5 ^6 H* qOSGI 规范包括了构建开放的可交付网络服务的各方面,OSGI规范又包括了以下子规范。 6 C- h% C4 v4 k' E) T% j# s3 C
Framework规范(OSGI核心,提供一个安全的可管理的Java Framework来部署可扩展的Java服务。) . t' ]7 e0 Q C% x1 J9 n
Package Admin Service规范(来管理不同的Bundle之间的引用关系。当Bundle更新或者反安装时判断是否有其他的服务正在使用当前的Bundle)( Z d: [6 u. u
Start Level规范(定义了启动和停止一个OSGi Service Platform时,不同的Bundles的启动或者停止的先后顺序)
( B4 t& f$ o8 W/ ~# wPermission Admin Service规范(Bundle是否许可执行另外的Bundle的代码)
* y8 }; W; N$ [8 L2 {5 BURL Handlers Service规范(怎样注册URL Schema,如何将java.io.InputStream对象转换为特定的Java对象), p3 B; {, v* @7 \; g
Log Service规范 (以下略。。。)# d. K) h) u3 U6 A8 n
Configuration Admin Service规范
3 f! k' ?- C& aDevice Access Specification; @9 s# r3 _* Z
User Admin Service Specification: [6 d( ~9 b4 v
IO Connector Service Specification
6 Q2 H( l9 t$ v9 ~( d. H" R1 o* JHttp Service Specification
l/ p7 ?) o' q. x5 i& D; BPreference Service Specification0 R* h+ O2 I& a
Wire Admin Service Specification
% l. V, f. s5 T8 O iXML Parser Service Specification$ O- t) }; ]5 k, {$ U
Metatype Specification
1 ?0 a# ^$ S/ z$ o* hService Tracker Specification
/ ^- F! k9 w, }- y4 J8 hMeasurment and State Specification
6 K' ]! U/ d9 I( F6 pPosition Specification
0 F, I+ `1 u* LExecution Environment Specfication- J' a S5 H: V; c) [
OSGI Framework
/ h4 ~2 E4 v m- \2 g# h; WFramework是OSGI Service Platform规范的核心组成部分。它提供了一个通用的、安全可管理的Java framework。通过这个Framework可以支持一种叫做bundles的Service application的部署和扩展。3 l" P6 L! f+ k& ?# u4 {- O
OSGI兼容设备可以下载并且安装OSGI bundles,也可一当他们不再需要的时候删除。bundles安装后会注册一定数量的Services,并被由同一个Framework下的其他bundles使用。9 l+ J2 @, w4 z: _, C; ]& b: [/ ?" f
在一个动态扩展的的 OSGI环境中,Framework管理bundles的安装和更新。同时也管理bundles和Services之间的依赖关系。
8 H9 o+ v8 ^( L- g: \5 ^, T5 TFramework提供给bundle开发者必须的资源来在Java平台上开发,为开发的bundles提供了代码动态加载的功能, 也使得开发者开发、部署一个大规模的Services变的很容易。# `1 r. c( ^' P! F( @! 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# B3 u* z' n0 s9 Q! q
一个一致的编程模型帮助开发者可以应付一些可估计的危急错误。Framework将会运行在不同的硬件环境上,但一致的接口确保软件组建可以运行在一致的服务接口上。
8 y/ j, G t% h2 w% |The Bundle Object
) ]6 }: N/ o; l8 I$ E对于每一个安装在OSGI Service Platform的bundle都有一个与之关联的bundle object。一个bundle对象用来管理bundle的生命周期。这项工作通常由Management Agent来做。
# e7 a/ ^) c% n: X+ FBundle State- V6 w7 a* _/ o8 j: d2 ~9 A2 a7 U! y" V3 ?
bundle有以下状态;
6 N/ g5 J. @. WINSTALLED – The bundle has been successfully installed. Native code clauses must have been validated.
+ b* R; `: R2 q3 D1 ^: }1 GRESOLVED – All Java classes that the bundle needs are available. This state indicates that the bundle is either ready to be started or has stopped.
9 w; n! w& G# R1 X( lSTARTING – The bundle is being started, and the BundleActivato r. start method has been called and has not yet returned.
) t8 {8 j0 j7 L. V4 U7 ZSTOPPING – The bundle is being stopped, and the BundleActivato r. stop method has been called and has not yet returned.1 l, k8 G4 x5 k9 Z
ACTIVE – The bundle has successfully started and is running.
* K* x" K; N- e# U' F0 aUNINSTALLED – The bundle has been uninstalled. It cannot move into another state.
4 N" I; k* I9 t2 Ueclipse 3.0并没有用OSGI替换掉原来的PlugIn机制。它只是做了与标准兼容的工作:给用户提供了一系列的API来访问,在这个过程中,就必须要做一些改 变(比如plugin registry和loading机制)来同OSGI标准完全兼容。最初的Plugin核心只支持静态的扩展,就是说,如果要改变一个已经存在的Plug 就必须重启core,也就是要退出Eclipse并重启。 C5 g$ P5 C# B% v7 m+ q
有很多人问Eclipse为什么要兼容OSGI规范而不是其他的规范呢?0 |. J, {0 ~2 H4 h$ [
在 Eclipse被捐赠出来以前,Eclipse由OTI来开发,其目标是开发一个嵌入式Java软件的开发平台。互联网上现在仍然由很多的连接指向 Visual Age Micro Edition (VAME). 这也是SWT被构思的一个原因,他们想将SWT使用在嵌入式设备中的用户界面。这种渊源关系解释了当时为什么选择OSGI规范。/ \( c7 h' D |; i/ g
另外一个原因是除了OSGI没有其他的规范。OSGI规范在轻量级服务架构应用方面被广泛的支持。而且OSGI被好多电信业的知名公司和一些其他行业的知名公司所支持。他们需要使用OSGI来同Sun的J2ME来抗衡。 |
|