鲜花( 0) 鸡蛋( 0)
|
OSGi是Open Service Gateway Initiative的简称,该组织建立于1999年,是一个非赢利机构,旨在建立一个开放的服务规范,为通过网络向设备提供服务建立开放的标准。) X9 b0 m" Y* D/ y0 u
OSGI 规范包括了构建开放的可交付网络服务的各方面,OSGI规范又包括了以下子规范。 $ U d" \( |4 p8 @
Framework规范(OSGI核心,提供一个安全的可管理的Java Framework来部署可扩展的Java服务。)
" T) k9 ^" D" ^! _1 \Package Admin Service规范(来管理不同的Bundle之间的引用关系。当Bundle更新或者反安装时判断是否有其他的服务正在使用当前的Bundle)7 y. i& M1 [/ w& ?0 f# c
Start Level规范(定义了启动和停止一个OSGi Service Platform时,不同的Bundles的启动或者停止的先后顺序)9 T% f4 `4 N$ d. Y, r
Permission Admin Service规范(Bundle是否许可执行另外的Bundle的代码)
A' g) w4 I: N- q4 eURL Handlers Service规范(怎样注册URL Schema,如何将java.io.InputStream对象转换为特定的Java对象)
- T4 Y* [ m7 k- c7 QLog Service规范 (以下略。。。)6 U# `7 @2 l) b
Configuration Admin Service规范
- b# a3 u4 y* N, nDevice Access Specification r$ u& }. w# m+ a& M
User Admin Service Specification
) t z' ?, K/ H0 h1 H# r1 _IO Connector Service Specification8 ^3 n' F4 G$ l
Http Service Specification7 `# `" S" l7 b" C1 r! `. V
Preference Service Specification. O; W) e% A# d' P" ^: V3 o
Wire Admin Service Specification t0 T1 k! \' Q) X% e
XML Parser Service Specification
_0 f% z+ y6 i" S) n/ p- m) s6 UMetatype Specification) f7 ] |" }7 m* b* i6 Z% I% X \
Service Tracker Specification
! _- E' t+ z# MMeasurment and State Specification
/ P3 L# h# F* z( x' fPosition Specification+ M# ?( c9 ^4 k B: S, G) r
Execution Environment Specfication
; l* k$ m! c7 b; KOSGI Framework
& I3 Z7 b1 [$ k/ XFramework是OSGI Service Platform规范的核心组成部分。它提供了一个通用的、安全可管理的Java framework。通过这个Framework可以支持一种叫做bundles的Service application的部署和扩展。 w0 Y* y! d- `) V: B( G
OSGI兼容设备可以下载并且安装OSGI bundles,也可一当他们不再需要的时候删除。bundles安装后会注册一定数量的Services,并被由同一个Framework下的其他bundles使用。" c. V0 J; E6 K
在一个动态扩展的的 OSGI环境中,Framework管理bundles的安装和更新。同时也管理bundles和Services之间的依赖关系。
& y7 D! N. p, E& AFramework提供给bundle开发者必须的资源来在Java平台上开发,为开发的bundles提供了代码动态加载的功能, 也使得开发者开发、部署一个大规模的Services变的很容易。
0 h$ Y6 f6 u1 [5 O7 Y4 |1 G5 Q( 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.; ~1 H: U( E; f; q; T9 V" o( s4 L8 ^
一个一致的编程模型帮助开发者可以应付一些可估计的危急错误。Framework将会运行在不同的硬件环境上,但一致的接口确保软件组建可以运行在一致的服务接口上。
- `% R$ u( @6 q' a* x, R( w4 P, GThe Bundle Object
8 L; H# c# Q( ?' u7 J4 v# U对于每一个安装在OSGI Service Platform的bundle都有一个与之关联的bundle object。一个bundle对象用来管理bundle的生命周期。这项工作通常由Management Agent来做。+ m! @1 o3 [- k) T- o* `/ t9 w3 Y
Bundle State7 a5 Z3 E% S( e3 Z8 L
bundle有以下状态;* b8 G0 U8 L6 J% o. l
INSTALLED – The bundle has been successfully installed. Native code clauses must have been validated.% _. m* d) p( H) Y0 T5 `) e( d% L+ ]( f
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.
s2 @. z1 ?# L$ i8 S! v, oSTARTING – The bundle is being started, and the BundleActivato r. start method has been called and has not yet returned.
C5 Z, s/ w" `% x |0 `STOPPING – The bundle is being stopped, and the BundleActivato r. stop method has been called and has not yet returned.) r c1 o! m5 m$ j. \. A
ACTIVE – The bundle has successfully started and is running.) `# Z% \4 N! N- U: |2 n5 O
UNINSTALLED – The bundle has been uninstalled. It cannot move into another state.
8 |8 s) g7 F" f7 S' Z! k; {eclipse 3.0并没有用OSGI替换掉原来的PlugIn机制。它只是做了与标准兼容的工作:给用户提供了一系列的API来访问,在这个过程中,就必须要做一些改 变(比如plugin registry和loading机制)来同OSGI标准完全兼容。最初的Plugin核心只支持静态的扩展,就是说,如果要改变一个已经存在的Plug 就必须重启core,也就是要退出Eclipse并重启。
- v7 L6 @( Q3 H; i+ m& J4 I有很多人问Eclipse为什么要兼容OSGI规范而不是其他的规范呢?( T* k4 O/ ]0 B: Q0 V8 ~
在 Eclipse被捐赠出来以前,Eclipse由OTI来开发,其目标是开发一个嵌入式Java软件的开发平台。互联网上现在仍然由很多的连接指向 Visual Age Micro Edition (VAME). 这也是SWT被构思的一个原因,他们想将SWT使用在嵌入式设备中的用户界面。这种渊源关系解释了当时为什么选择OSGI规范。) j4 T- G+ `5 p, y: q' _$ ^4 i
另外一个原因是除了OSGI没有其他的规范。OSGI规范在轻量级服务架构应用方面被广泛的支持。而且OSGI被好多电信业的知名公司和一些其他行业的知名公司所支持。他们需要使用OSGI来同Sun的J2ME来抗衡。 |
|