 鲜花( 0)  鸡蛋( 0)
|
OSGi是Open Service Gateway Initiative的简称,该组织建立于1999年,是一个非赢利机构,旨在建立一个开放的服务规范,为通过网络向设备提供服务建立开放的标准。
7 h* m8 O# v9 rOSGI 规范包括了构建开放的可交付网络服务的各方面,OSGI规范又包括了以下子规范。
! m" r k+ Z0 u) f m$ E* i6 xFramework规范(OSGI核心,提供一个安全的可管理的Java Framework来部署可扩展的Java服务。)
- @8 A0 t7 J$ V& R% X# }2 xPackage Admin Service规范(来管理不同的Bundle之间的引用关系。当Bundle更新或者反安装时判断是否有其他的服务正在使用当前的Bundle)7 S7 S6 g! Y7 h3 P- Z2 @
Start Level规范(定义了启动和停止一个OSGi Service Platform时,不同的Bundles的启动或者停止的先后顺序) l2 X' \0 y4 _$ g, L+ N
Permission Admin Service规范(Bundle是否许可执行另外的Bundle的代码)
" G5 l4 V5 U; w1 @- ?5 s1 r+ F4 VURL Handlers Service规范(怎样注册URL Schema,如何将java.io.InputStream对象转换为特定的Java对象)
4 C2 p. v& J# f7 H6 k# FLog Service规范 (以下略。。。)
! ^+ ^1 G; n* X o; X i' l. |Configuration Admin Service规范
+ A- c$ ~/ C# D" h5 Y* lDevice Access Specification
4 W% \8 t( H# [- w. RUser Admin Service Specification! O `- v4 |, r, |- C, I M! Q
IO Connector Service Specification
- ~% s: B3 ]& F* \! z3 N. P9 bHttp Service Specification
1 E3 w( h* [4 N* Z( g( V9 S/ C! P" w! ZPreference Service Specification
; v ~; F |2 f( T% l: b% qWire Admin Service Specification
% ]3 o; H7 O/ rXML Parser Service Specification
+ Z0 ^0 l! d8 q9 J8 V% ]2 hMetatype Specification
; w- t8 O$ U5 b* U2 e! l0 l; mService Tracker Specification* P o! M, Y$ K2 K ~
Measurment and State Specification
! U) A1 ~+ l# \# V7 z3 S3 {Position Specification/ W/ _' m+ N5 F( c
Execution Environment Specfication( o* m8 W i, n! d9 \
OSGI Framework
. K# O! }8 N- }+ U8 { fFramework是OSGI Service Platform规范的核心组成部分。它提供了一个通用的、安全可管理的Java framework。通过这个Framework可以支持一种叫做bundles的Service application的部署和扩展。9 W5 [$ E7 g4 `3 R6 w" ~
OSGI兼容设备可以下载并且安装OSGI bundles,也可一当他们不再需要的时候删除。bundles安装后会注册一定数量的Services,并被由同一个Framework下的其他bundles使用。% h& h$ d0 I' Q* Q W) [
在一个动态扩展的的 OSGI环境中,Framework管理bundles的安装和更新。同时也管理bundles和Services之间的依赖关系。) b& \ T6 m* t% g0 O! X
Framework提供给bundle开发者必须的资源来在Java平台上开发,为开发的bundles提供了代码动态加载的功能, 也使得开发者开发、部署一个大规模的Services变的很容易。; O! B( p& R; A/ h3 _6 J& ~0 N; k& Y8 _
其 次,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.+ W, n' [, w- ^) Q. L
一个一致的编程模型帮助开发者可以应付一些可估计的危急错误。Framework将会运行在不同的硬件环境上,但一致的接口确保软件组建可以运行在一致的服务接口上。
/ ]: I3 y. _, ^7 i, _The Bundle Object' b: R/ D8 f, a8 G& z5 c- D
对于每一个安装在OSGI Service Platform的bundle都有一个与之关联的bundle object。一个bundle对象用来管理bundle的生命周期。这项工作通常由Management Agent来做。; ?2 N/ p1 m2 \( m: k* _
Bundle State
) C6 g0 \. r$ @2 j! @bundle有以下状态;
N: o( q7 q( E; a7 t) e! HINSTALLED – The bundle has been successfully installed. Native code clauses must have been validated.
- e2 o, v D9 F/ E3 B+ S3 j$ | [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 B5 J" R/ D6 e2 k$ D+ i5 BSTARTING – The bundle is being started, and the BundleActivato r. start method has been called and has not yet returned.
3 n: U% C3 e3 T5 ?, J$ \5 aSTOPPING – The bundle is being stopped, and the BundleActivato r. stop method has been called and has not yet returned.9 m% ?4 i, i+ W
ACTIVE – The bundle has successfully started and is running.
% d# n, G! H6 R, G# rUNINSTALLED – The bundle has been uninstalled. It cannot move into another state.0 _& f& E7 \$ f2 {
eclipse 3.0并没有用OSGI替换掉原来的PlugIn机制。它只是做了与标准兼容的工作:给用户提供了一系列的API来访问,在这个过程中,就必须要做一些改 变(比如plugin registry和loading机制)来同OSGI标准完全兼容。最初的Plugin核心只支持静态的扩展,就是说,如果要改变一个已经存在的Plug 就必须重启core,也就是要退出Eclipse并重启。6 O% D, e% R- D
有很多人问Eclipse为什么要兼容OSGI规范而不是其他的规范呢?
( @# o0 Z/ Y# [! l在 Eclipse被捐赠出来以前,Eclipse由OTI来开发,其目标是开发一个嵌入式Java软件的开发平台。互联网上现在仍然由很多的连接指向 Visual Age Micro Edition (VAME). 这也是SWT被构思的一个原因,他们想将SWT使用在嵌入式设备中的用户界面。这种渊源关系解释了当时为什么选择OSGI规范。* t6 x( U `' H V
另外一个原因是除了OSGI没有其他的规范。OSGI规范在轻量级服务架构应用方面被广泛的支持。而且OSGI被好多电信业的知名公司和一些其他行业的知名公司所支持。他们需要使用OSGI来同Sun的J2ME来抗衡。 |
|