 鲜花( 0)  鸡蛋( 0)
|
OSGi是Open Service Gateway Initiative的简称,该组织建立于1999年,是一个非赢利机构,旨在建立一个开放的服务规范,为通过网络向设备提供服务建立开放的标准。
) Z9 O8 [+ {: Q' F& U- m$ SOSGI 规范包括了构建开放的可交付网络服务的各方面,OSGI规范又包括了以下子规范。 3 G6 Q7 q+ ] u S* a+ M$ I. }
Framework规范(OSGI核心,提供一个安全的可管理的Java Framework来部署可扩展的Java服务。) $ N7 e# p" w* k
Package Admin Service规范(来管理不同的Bundle之间的引用关系。当Bundle更新或者反安装时判断是否有其他的服务正在使用当前的Bundle)
" @4 Q- W, J, V# I, _: DStart Level规范(定义了启动和停止一个OSGi Service Platform时,不同的Bundles的启动或者停止的先后顺序)
9 ]. N& @ f+ a0 q0 o4 ZPermission Admin Service规范(Bundle是否许可执行另外的Bundle的代码)
; u/ h0 U' U) i9 m/ {2 _URL Handlers Service规范(怎样注册URL Schema,如何将java.io.InputStream对象转换为特定的Java对象)
; c/ j" _* D* X! l4 dLog Service规范 (以下略。。。)
/ `8 T$ f( F9 L, sConfiguration Admin Service规范
# E, j5 ] D9 F7 o E0 bDevice Access Specification$ {. \% d, b# U$ ~5 S: h) @
User Admin Service Specification# v1 }9 N! S/ l) @8 k
IO Connector Service Specification
" t; m+ d _' N4 ~. x3 aHttp Service Specification
' m& v5 Z9 G! Y* vPreference Service Specification* q& U7 _8 a- \, C% ?3 a4 U) e( T/ H
Wire Admin Service Specification) [2 _4 U- F, L" ~5 p8 H! v( E6 B
XML Parser Service Specification* W& U [6 ]8 w$ Z8 }5 |
Metatype Specification
( o, z9 O/ I7 eService Tracker Specification
1 h: t8 f8 J6 S% z% {+ ?" ~& v" X! P' iMeasurment and State Specification
& C8 x9 Y& a8 x& k( c8 X/ F: W% \: ]Position Specification3 \6 d# h6 h$ J, M6 y: P
Execution Environment Specfication
?0 `" b0 L5 P9 M$ LOSGI Framework3 R" o" c7 B& O' N; \+ |4 s
Framework是OSGI Service Platform规范的核心组成部分。它提供了一个通用的、安全可管理的Java framework。通过这个Framework可以支持一种叫做bundles的Service application的部署和扩展。) G; f9 d4 g* @ @. _' B& z& ?: C
OSGI兼容设备可以下载并且安装OSGI bundles,也可一当他们不再需要的时候删除。bundles安装后会注册一定数量的Services,并被由同一个Framework下的其他bundles使用。" P! {4 K- y( Q" I- l7 |- `/ n- w. j& K
在一个动态扩展的的 OSGI环境中,Framework管理bundles的安装和更新。同时也管理bundles和Services之间的依赖关系。+ h- H: x. b1 M: ^, z
Framework提供给bundle开发者必须的资源来在Java平台上开发,为开发的bundles提供了代码动态加载的功能, 也使得开发者开发、部署一个大规模的Services变的很容易。
& T- o9 Z6 n) D, K$ j2 X其 次,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.; q: ?1 |- K, l+ y7 q9 G( }; a
一个一致的编程模型帮助开发者可以应付一些可估计的危急错误。Framework将会运行在不同的硬件环境上,但一致的接口确保软件组建可以运行在一致的服务接口上。
6 B; k- w! {6 P2 GThe Bundle Object
+ x& A e9 o# V* ]2 t. m4 W- K对于每一个安装在OSGI Service Platform的bundle都有一个与之关联的bundle object。一个bundle对象用来管理bundle的生命周期。这项工作通常由Management Agent来做。8 u& Z, }% u- c- C
Bundle State. J" n! ]5 _$ I0 P& o' v& a1 [7 r; H( D
bundle有以下状态;
, s2 A3 p x, U B& C# MINSTALLED – The bundle has been successfully installed. Native code clauses must have been validated.: C) A! {! l0 r
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.
# A2 }. ~6 j, zSTARTING – The bundle is being started, and the BundleActivato r. start method has been called and has not yet returned.
2 @ |0 ]7 ]1 T1 p: bSTOPPING – The bundle is being stopped, and the BundleActivato r. stop method has been called and has not yet returned.
" @: P; J# j4 m5 U$ `5 W CACTIVE – The bundle has successfully started and is running.; N: ? _- U a4 D" y! _5 ?) W
UNINSTALLED – The bundle has been uninstalled. It cannot move into another state.0 P" c+ K( K, Q. h% D, y
eclipse 3.0并没有用OSGI替换掉原来的PlugIn机制。它只是做了与标准兼容的工作:给用户提供了一系列的API来访问,在这个过程中,就必须要做一些改 变(比如plugin registry和loading机制)来同OSGI标准完全兼容。最初的Plugin核心只支持静态的扩展,就是说,如果要改变一个已经存在的Plug 就必须重启core,也就是要退出Eclipse并重启。
8 l; M0 x" x' g. \5 j有很多人问Eclipse为什么要兼容OSGI规范而不是其他的规范呢?
# r) {% N. R8 B& [( h, M! Z Z在 Eclipse被捐赠出来以前,Eclipse由OTI来开发,其目标是开发一个嵌入式Java软件的开发平台。互联网上现在仍然由很多的连接指向 Visual Age Micro Edition (VAME). 这也是SWT被构思的一个原因,他们想将SWT使用在嵌入式设备中的用户界面。这种渊源关系解释了当时为什么选择OSGI规范。% i' s4 e t; U! U. c
另外一个原因是除了OSGI没有其他的规范。OSGI规范在轻量级服务架构应用方面被广泛的支持。而且OSGI被好多电信业的知名公司和一些其他行业的知名公司所支持。他们需要使用OSGI来同Sun的J2ME来抗衡。 |
|