 鲜花( 0)  鸡蛋( 0)
|
OSGi是Open Service Gateway Initiative的简称,该组织建立于1999年,是一个非赢利机构,旨在建立一个开放的服务规范,为通过网络向设备提供服务建立开放的标准。
5 P. K9 F$ W7 V' d- q% B5 d# h2 \OSGI 规范包括了构建开放的可交付网络服务的各方面,OSGI规范又包括了以下子规范。
' F4 Q5 Y- h# n- t6 iFramework规范(OSGI核心,提供一个安全的可管理的Java Framework来部署可扩展的Java服务。) ! e. l4 i" H) ^* T
Package Admin Service规范(来管理不同的Bundle之间的引用关系。当Bundle更新或者反安装时判断是否有其他的服务正在使用当前的Bundle)5 I. Z9 M: _8 N/ C& d
Start Level规范(定义了启动和停止一个OSGi Service Platform时,不同的Bundles的启动或者停止的先后顺序)/ y0 b. X6 j" X( e) J m
Permission Admin Service规范(Bundle是否许可执行另外的Bundle的代码)
) n+ p( [# j/ K) HURL Handlers Service规范(怎样注册URL Schema,如何将java.io.InputStream对象转换为特定的Java对象)" f! R. \; I7 i1 {! i
Log Service规范 (以下略。。。)& v+ ^ q/ K* H1 v. ^
Configuration Admin Service规范& x4 G l1 J3 T( X1 n
Device Access Specification0 _! Z+ T, V: | v
User Admin Service Specification
1 o4 v! T N' ?1 D6 }IO Connector Service Specification
! O2 o* Y) v" w. O. {Http Service Specification
$ k) ]6 ]9 m. EPreference Service Specification: b* O; r3 i' F3 C) @2 Z' m( M& p
Wire Admin Service Specification: H9 F [4 T) e# N- l' H
XML Parser Service Specification a/ K) I/ _7 Y' g
Metatype Specification
7 G: O' |$ b8 W% l' J1 XService Tracker Specification
+ a3 w$ @% Q2 [0 lMeasurment and State Specification
* x1 j, m7 R: L# }! B' Y: YPosition Specification* e, \4 T; M1 U/ h0 t
Execution Environment Specfication7 a" |, L) \5 {( ?* p
OSGI Framework
% G, h ]) b+ f, K) e4 e# uFramework是OSGI Service Platform规范的核心组成部分。它提供了一个通用的、安全可管理的Java framework。通过这个Framework可以支持一种叫做bundles的Service application的部署和扩展。
2 o. r& E8 j1 Y4 HOSGI兼容设备可以下载并且安装OSGI bundles,也可一当他们不再需要的时候删除。bundles安装后会注册一定数量的Services,并被由同一个Framework下的其他bundles使用。* P7 @% z; e2 N% \" \
在一个动态扩展的的 OSGI环境中,Framework管理bundles的安装和更新。同时也管理bundles和Services之间的依赖关系。
: ` Y7 w# V# HFramework提供给bundle开发者必须的资源来在Java平台上开发,为开发的bundles提供了代码动态加载的功能, 也使得开发者开发、部署一个大规模的Services变的很容易。$ {$ n6 C ]& n) A% d/ 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.) ]) H, z! x" i& x+ g
一个一致的编程模型帮助开发者可以应付一些可估计的危急错误。Framework将会运行在不同的硬件环境上,但一致的接口确保软件组建可以运行在一致的服务接口上。& [$ p! d5 P# W* m' K* C2 s l
The Bundle Object
# x' k; U) A6 h7 Y- L6 |对于每一个安装在OSGI Service Platform的bundle都有一个与之关联的bundle object。一个bundle对象用来管理bundle的生命周期。这项工作通常由Management Agent来做。3 `2 e( c! l+ ]1 l' }
Bundle State$ J0 f2 E0 r+ K& g2 t3 O ?
bundle有以下状态;* v0 g. V+ I/ l4 g
INSTALLED – The bundle has been successfully installed. Native code clauses must have been validated.- R. N4 S: S6 G9 f) 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.
3 x v9 ]( s& y1 P- k9 u. C' OSTARTING – The bundle is being started, and the BundleActivato r. start method has been called and has not yet returned.( k- P. m* i$ a% d/ Y% e+ U
STOPPING – The bundle is being stopped, and the BundleActivato r. stop method has been called and has not yet returned.
; c9 E% \2 c) D; I4 b9 f% g3 PACTIVE – The bundle has successfully started and is running.
3 M y+ }0 n7 Z; U* i1 ~ |UNINSTALLED – The bundle has been uninstalled. It cannot move into another state.% j/ R6 ?# K& a# q ]! I: _+ D
eclipse 3.0并没有用OSGI替换掉原来的PlugIn机制。它只是做了与标准兼容的工作:给用户提供了一系列的API来访问,在这个过程中,就必须要做一些改 变(比如plugin registry和loading机制)来同OSGI标准完全兼容。最初的Plugin核心只支持静态的扩展,就是说,如果要改变一个已经存在的Plug 就必须重启core,也就是要退出Eclipse并重启。' S' I" X4 W: ^1 Q8 K3 c; P4 B
有很多人问Eclipse为什么要兼容OSGI规范而不是其他的规范呢?
6 }/ o# O7 M+ i a* d9 K' B! P在 Eclipse被捐赠出来以前,Eclipse由OTI来开发,其目标是开发一个嵌入式Java软件的开发平台。互联网上现在仍然由很多的连接指向 Visual Age Micro Edition (VAME). 这也是SWT被构思的一个原因,他们想将SWT使用在嵌入式设备中的用户界面。这种渊源关系解释了当时为什么选择OSGI规范。& \+ V& v2 U# }0 Z$ s$ s. o% ?
另外一个原因是除了OSGI没有其他的规范。OSGI规范在轻量级服务架构应用方面被广泛的支持。而且OSGI被好多电信业的知名公司和一些其他行业的知名公司所支持。他们需要使用OSGI来同Sun的J2ME来抗衡。 |
|