 鲜花( 0)  鸡蛋( 0)
|
OSGi是Open Service Gateway Initiative的简称,该组织建立于1999年,是一个非赢利机构,旨在建立一个开放的服务规范,为通过网络向设备提供服务建立开放的标准。
! d' A0 d' P# l' i7 X( M& sOSGI 规范包括了构建开放的可交付网络服务的各方面,OSGI规范又包括了以下子规范。
/ i/ b! z* D$ y+ K; pFramework规范(OSGI核心,提供一个安全的可管理的Java Framework来部署可扩展的Java服务。) 4 G: o$ \2 S, L ?$ k0 O* V
Package Admin Service规范(来管理不同的Bundle之间的引用关系。当Bundle更新或者反安装时判断是否有其他的服务正在使用当前的Bundle)
0 b4 Q: R/ {$ x: J' TStart Level规范(定义了启动和停止一个OSGi Service Platform时,不同的Bundles的启动或者停止的先后顺序)
: q c$ B) r* |( F" m& b( _Permission Admin Service规范(Bundle是否许可执行另外的Bundle的代码)0 z8 i/ t6 w0 c9 L/ _- |
URL Handlers Service规范(怎样注册URL Schema,如何将java.io.InputStream对象转换为特定的Java对象)2 b3 T3 Y4 B5 U# T3 Z* m% C: K
Log Service规范 (以下略。。。)* {! p& y0 u( n* J
Configuration Admin Service规范* j! J& ?* F$ G% k2 G( N5 j2 z
Device Access Specification O( v' }1 A6 ?
User Admin Service Specification0 \" K4 A3 w, K) p7 W& G6 N
IO Connector Service Specification! A" j6 ^+ ?7 y2 V: X; b1 v
Http Service Specification
# Q: c$ Z; [ p" f3 e) QPreference Service Specification
7 Z! k/ _6 \' h) N0 j0 h8 SWire Admin Service Specification! }. u0 Z) C' g% c5 o# g; [
XML Parser Service Specification+ M6 i: E3 X) A# Z$ _$ Q
Metatype Specification
+ |3 N- h! o+ V+ Q# BService Tracker Specification
4 N1 A, l# i5 Y+ u. P1 d: cMeasurment and State Specification' Z$ Y" v S; W* n. u' v
Position Specification
& {, ?# _4 z A" P$ cExecution Environment Specfication
$ I5 y# H. R F; @6 }OSGI Framework
" t$ P( S$ ^$ {( W" l! rFramework是OSGI Service Platform规范的核心组成部分。它提供了一个通用的、安全可管理的Java framework。通过这个Framework可以支持一种叫做bundles的Service application的部署和扩展。$ o( M0 ], H8 j! T5 ^! s
OSGI兼容设备可以下载并且安装OSGI bundles,也可一当他们不再需要的时候删除。bundles安装后会注册一定数量的Services,并被由同一个Framework下的其他bundles使用。
1 g3 I' F) t+ a在一个动态扩展的的 OSGI环境中,Framework管理bundles的安装和更新。同时也管理bundles和Services之间的依赖关系。+ J5 D. s/ B& z* w8 ^* b; o
Framework提供给bundle开发者必须的资源来在Java平台上开发,为开发的bundles提供了代码动态加载的功能, 也使得开发者开发、部署一个大规模的Services变的很容易。8 \6 _0 O, D, O3 G5 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 V- b5 a% K4 { M
一个一致的编程模型帮助开发者可以应付一些可估计的危急错误。Framework将会运行在不同的硬件环境上,但一致的接口确保软件组建可以运行在一致的服务接口上。# ?1 {; I: Y' H" F' r: v- N
The Bundle Object& {7 e; e5 |0 i& T: z6 K$ l6 q
对于每一个安装在OSGI Service Platform的bundle都有一个与之关联的bundle object。一个bundle对象用来管理bundle的生命周期。这项工作通常由Management Agent来做。) k9 j8 M( u5 {9 J
Bundle State
2 b) o7 m0 S* ybundle有以下状态;( v( i& B! G6 O/ D8 w% O& i. z- g1 g
INSTALLED – The bundle has been successfully installed. Native code clauses must have been validated.
' M P8 b" L, 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.+ v$ ]5 j" u5 Z' x& J
STARTING – The bundle is being started, and the BundleActivato r. start method has been called and has not yet returned.
; H4 R/ u+ F2 O; fSTOPPING – The bundle is being stopped, and the BundleActivato r. stop method has been called and has not yet returned.
- w/ q* e% b. _! ZACTIVE – The bundle has successfully started and is running.' a, e: J `2 w5 q
UNINSTALLED – The bundle has been uninstalled. It cannot move into another state.
5 F1 o& F6 t; ^* ]eclipse 3.0并没有用OSGI替换掉原来的PlugIn机制。它只是做了与标准兼容的工作:给用户提供了一系列的API来访问,在这个过程中,就必须要做一些改 变(比如plugin registry和loading机制)来同OSGI标准完全兼容。最初的Plugin核心只支持静态的扩展,就是说,如果要改变一个已经存在的Plug 就必须重启core,也就是要退出Eclipse并重启。
& ?* ^, x5 s2 _ O) P8 V, m$ S有很多人问Eclipse为什么要兼容OSGI规范而不是其他的规范呢?% T$ v1 L( K! B
在 Eclipse被捐赠出来以前,Eclipse由OTI来开发,其目标是开发一个嵌入式Java软件的开发平台。互联网上现在仍然由很多的连接指向 Visual Age Micro Edition (VAME). 这也是SWT被构思的一个原因,他们想将SWT使用在嵌入式设备中的用户界面。这种渊源关系解释了当时为什么选择OSGI规范。7 S: |0 o* J0 n. X0 Q1 K2 l0 g
另外一个原因是除了OSGI没有其他的规范。OSGI规范在轻量级服务架构应用方面被广泛的支持。而且OSGI被好多电信业的知名公司和一些其他行业的知名公司所支持。他们需要使用OSGI来同Sun的J2ME来抗衡。 |
|