 鲜花( 0)  鸡蛋( 0)
|
OSGi是Open Service Gateway Initiative的简称,该组织建立于1999年,是一个非赢利机构,旨在建立一个开放的服务规范,为通过网络向设备提供服务建立开放的标准。
7 c" v* |( T& ?1 IOSGI 规范包括了构建开放的可交付网络服务的各方面,OSGI规范又包括了以下子规范。 8 o- o- ?0 e5 N
Framework规范(OSGI核心,提供一个安全的可管理的Java Framework来部署可扩展的Java服务。)
5 a, i( [) g. r6 b y% r4 BPackage Admin Service规范(来管理不同的Bundle之间的引用关系。当Bundle更新或者反安装时判断是否有其他的服务正在使用当前的Bundle)3 t0 P5 ^) q/ E3 K
Start Level规范(定义了启动和停止一个OSGi Service Platform时,不同的Bundles的启动或者停止的先后顺序)7 S B8 L4 o d$ Y( L
Permission Admin Service规范(Bundle是否许可执行另外的Bundle的代码)
9 e9 l% U2 y: k, LURL Handlers Service规范(怎样注册URL Schema,如何将java.io.InputStream对象转换为特定的Java对象)$ j5 X1 [+ s9 R1 x% z
Log Service规范 (以下略。。。)
4 X" r! v j8 i z& {4 WConfiguration Admin Service规范. @) d$ O% v/ F$ ]
Device Access Specification* B7 N! ]& b5 P* m
User Admin Service Specification
5 q+ O" x% x! \9 J S: j1 t1 |/ KIO Connector Service Specification
3 ^9 t/ U9 N ~9 r+ r4 g/ fHttp Service Specification
$ r7 U5 { q2 V5 kPreference Service Specification
$ Z) `# R6 q! MWire Admin Service Specification
9 N5 _1 d$ L( Z4 C+ {XML Parser Service Specification* X: Z, o# k3 ^( B$ W9 n
Metatype Specification
. |1 N1 o+ G5 W" d4 EService Tracker Specification
1 y, E1 R \" O' K. UMeasurment and State Specification/ |4 T/ Y: }' P0 {* |
Position Specification
' W" M( {4 D1 m( }) H) hExecution Environment Specfication5 Y7 O- d( x: s) Z
OSGI Framework
1 Q8 f9 M# v5 |# j% l% XFramework是OSGI Service Platform规范的核心组成部分。它提供了一个通用的、安全可管理的Java framework。通过这个Framework可以支持一种叫做bundles的Service application的部署和扩展。- l* D# \* X$ ^$ I* Y3 o( T7 {
OSGI兼容设备可以下载并且安装OSGI bundles,也可一当他们不再需要的时候删除。bundles安装后会注册一定数量的Services,并被由同一个Framework下的其他bundles使用。8 t0 K B( U: ~% a& B/ S5 w5 j
在一个动态扩展的的 OSGI环境中,Framework管理bundles的安装和更新。同时也管理bundles和Services之间的依赖关系。. z& h8 d' v$ d* o
Framework提供给bundle开发者必须的资源来在Java平台上开发,为开发的bundles提供了代码动态加载的功能, 也使得开发者开发、部署一个大规模的Services变的很容易。+ o7 b! [* q9 @6 I% {* c& V
其 次,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.) \* W5 x7 x8 Y2 M# l
一个一致的编程模型帮助开发者可以应付一些可估计的危急错误。Framework将会运行在不同的硬件环境上,但一致的接口确保软件组建可以运行在一致的服务接口上。! Z* m$ [. P [. D# ]
The Bundle Object4 _! e' ^" W2 h4 T! u* v3 g7 h
对于每一个安装在OSGI Service Platform的bundle都有一个与之关联的bundle object。一个bundle对象用来管理bundle的生命周期。这项工作通常由Management Agent来做。
! l( x: y- Z1 C/ m1 }: V- H1 HBundle State
9 Q+ l3 j/ Q' h C$ x& \bundle有以下状态;
m8 k- H* E, T/ PINSTALLED – The bundle has been successfully installed. Native code clauses must have been validated.9 E8 x8 H( s) C
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.
$ {4 r% R- S: W. E9 E" ~STARTING – The bundle is being started, and the BundleActivato r. start method has been called and has not yet returned.. c) D+ f" ?1 D v
STOPPING – The bundle is being stopped, and the BundleActivato r. stop method has been called and has not yet returned.1 @- }! O/ J, a; L8 w
ACTIVE – The bundle has successfully started and is running.
! L) a& C" W/ q3 k6 \; BUNINSTALLED – The bundle has been uninstalled. It cannot move into another state.
. ^" g$ X* r' F/ _( d5 [+ Z) reclipse 3.0并没有用OSGI替换掉原来的PlugIn机制。它只是做了与标准兼容的工作:给用户提供了一系列的API来访问,在这个过程中,就必须要做一些改 变(比如plugin registry和loading机制)来同OSGI标准完全兼容。最初的Plugin核心只支持静态的扩展,就是说,如果要改变一个已经存在的Plug 就必须重启core,也就是要退出Eclipse并重启。
' T; G* a" M" q4 ~8 i% j有很多人问Eclipse为什么要兼容OSGI规范而不是其他的规范呢?
+ ^% {& Q! ~8 p& u. W/ }在 Eclipse被捐赠出来以前,Eclipse由OTI来开发,其目标是开发一个嵌入式Java软件的开发平台。互联网上现在仍然由很多的连接指向 Visual Age Micro Edition (VAME). 这也是SWT被构思的一个原因,他们想将SWT使用在嵌入式设备中的用户界面。这种渊源关系解释了当时为什么选择OSGI规范。+ |1 e) k& s9 X. n1 \# L6 \/ r7 {4 k
另外一个原因是除了OSGI没有其他的规范。OSGI规范在轻量级服务架构应用方面被广泛的支持。而且OSGI被好多电信业的知名公司和一些其他行业的知名公司所支持。他们需要使用OSGI来同Sun的J2ME来抗衡。 |
|