 鲜花( 0)  鸡蛋( 0)
|
OSGi是Open Service Gateway Initiative的简称,该组织建立于1999年,是一个非赢利机构,旨在建立一个开放的服务规范,为通过网络向设备提供服务建立开放的标准。# L( \$ ^* y3 ^* U# |
OSGI 规范包括了构建开放的可交付网络服务的各方面,OSGI规范又包括了以下子规范。
4 Q! d' b7 e0 }% c2 S. TFramework规范(OSGI核心,提供一个安全的可管理的Java Framework来部署可扩展的Java服务。)
: H; j! v2 z2 @: c* F iPackage Admin Service规范(来管理不同的Bundle之间的引用关系。当Bundle更新或者反安装时判断是否有其他的服务正在使用当前的Bundle)
! w% F' O5 U3 mStart Level规范(定义了启动和停止一个OSGi Service Platform时,不同的Bundles的启动或者停止的先后顺序)$ r3 s7 q6 A+ j. U/ b* n6 o- F
Permission Admin Service规范(Bundle是否许可执行另外的Bundle的代码)& `: R* y1 p. Y8 L7 t6 Z
URL Handlers Service规范(怎样注册URL Schema,如何将java.io.InputStream对象转换为特定的Java对象)
& d, {4 n* E# e$ m# {: S; \Log Service规范 (以下略。。。)
) `$ k$ X: z+ R7 F; T sConfiguration Admin Service规范
5 q# G( ?3 E) Y3 sDevice Access Specification
$ h+ L# I( |3 v9 `1 `/ lUser Admin Service Specification$ J! z( H0 m3 D% u+ U
IO Connector Service Specification% }$ S8 L( N9 c: S$ R- z0 |
Http Service Specification6 X- X/ e. J4 s) i% {; q0 D" Q% P2 z" Y
Preference Service Specification
5 y9 `9 t0 ]* `3 n6 W Q* }) x CWire Admin Service Specification
' j2 {& D* ]3 _! E4 N. cXML Parser Service Specification
4 \! `- }0 v+ F- r5 YMetatype Specification- a7 X+ X9 N. B! x' S2 H8 C0 P
Service Tracker Specification
- v/ D, O) `( Z- _- U9 ^Measurment and State Specification
' i4 M8 N) j( ], ^: `Position Specification8 U+ w5 F/ h( U4 Y( p& I
Execution Environment Specfication4 j* K" F2 R1 E! ?4 _, r
OSGI Framework
1 `' N9 `, c" H" ] D1 z4 J0 yFramework是OSGI Service Platform规范的核心组成部分。它提供了一个通用的、安全可管理的Java framework。通过这个Framework可以支持一种叫做bundles的Service application的部署和扩展。
; b: O3 u3 A8 h3 K$ BOSGI兼容设备可以下载并且安装OSGI bundles,也可一当他们不再需要的时候删除。bundles安装后会注册一定数量的Services,并被由同一个Framework下的其他bundles使用。
4 p `8 x* ?% n0 |/ G在一个动态扩展的的 OSGI环境中,Framework管理bundles的安装和更新。同时也管理bundles和Services之间的依赖关系。& u; U# y0 a9 ?0 S. c
Framework提供给bundle开发者必须的资源来在Java平台上开发,为开发的bundles提供了代码动态加载的功能, 也使得开发者开发、部署一个大规模的Services变的很容易。9 ~2 @, A0 S! H
其 次,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.0 s% ^; J- d; X* P4 y1 Y7 ]& i
一个一致的编程模型帮助开发者可以应付一些可估计的危急错误。Framework将会运行在不同的硬件环境上,但一致的接口确保软件组建可以运行在一致的服务接口上。0 \1 ]9 G6 E9 ~% F# _1 f. O. k+ Z
The Bundle Object
( L/ S g; ]+ c' ^对于每一个安装在OSGI Service Platform的bundle都有一个与之关联的bundle object。一个bundle对象用来管理bundle的生命周期。这项工作通常由Management Agent来做。 y6 @9 O3 c: d: Y! W$ N
Bundle State
; V) N( b$ a* C7 C: @- zbundle有以下状态;( a) z- Q P$ M2 a3 f8 O' e+ h
INSTALLED – The bundle has been successfully installed. Native code clauses must have been validated.
4 W6 x) j2 Z8 L: cRESOLVED – All Java classes that the bundle needs are available. This state indicates that the bundle is either ready to be started or has stopped.- K! a8 i9 o( m/ \7 e
STARTING – The bundle is being started, and the BundleActivato r. start method has been called and has not yet returned.
% y8 w$ A0 G% _" g% jSTOPPING – The bundle is being stopped, and the BundleActivato r. stop method has been called and has not yet returned.
5 k: G! C7 z1 H% F0 @) RACTIVE – The bundle has successfully started and is running.
" u0 p- K- A2 XUNINSTALLED – The bundle has been uninstalled. It cannot move into another state.9 g! j$ N7 V$ D- {2 Y* ^7 [
eclipse 3.0并没有用OSGI替换掉原来的PlugIn机制。它只是做了与标准兼容的工作:给用户提供了一系列的API来访问,在这个过程中,就必须要做一些改 变(比如plugin registry和loading机制)来同OSGI标准完全兼容。最初的Plugin核心只支持静态的扩展,就是说,如果要改变一个已经存在的Plug 就必须重启core,也就是要退出Eclipse并重启。: f# e3 p! a: q' M. S
有很多人问Eclipse为什么要兼容OSGI规范而不是其他的规范呢?
# N* z9 V2 D/ q/ w K, I1 O# I在 Eclipse被捐赠出来以前,Eclipse由OTI来开发,其目标是开发一个嵌入式Java软件的开发平台。互联网上现在仍然由很多的连接指向 Visual Age Micro Edition (VAME). 这也是SWT被构思的一个原因,他们想将SWT使用在嵌入式设备中的用户界面。这种渊源关系解释了当时为什么选择OSGI规范。* ~# K6 O+ e* z( c7 C# s+ C4 c
另外一个原因是除了OSGI没有其他的规范。OSGI规范在轻量级服务架构应用方面被广泛的支持。而且OSGI被好多电信业的知名公司和一些其他行业的知名公司所支持。他们需要使用OSGI来同Sun的J2ME来抗衡。 |
|