鲜花( 0) 鸡蛋( 0)
|
OSGi是Open Service Gateway Initiative的简称,该组织建立于1999年,是一个非赢利机构,旨在建立一个开放的服务规范,为通过网络向设备提供服务建立开放的标准。! E; O5 k0 J& X7 H+ a6 e* }
OSGI 规范包括了构建开放的可交付网络服务的各方面,OSGI规范又包括了以下子规范。 3 `6 p& S! }0 v6 i
Framework规范(OSGI核心,提供一个安全的可管理的Java Framework来部署可扩展的Java服务。) # T% M5 B6 b# V4 W- y$ p
Package Admin Service规范(来管理不同的Bundle之间的引用关系。当Bundle更新或者反安装时判断是否有其他的服务正在使用当前的Bundle), V |' \9 q! C% `
Start Level规范(定义了启动和停止一个OSGi Service Platform时,不同的Bundles的启动或者停止的先后顺序)
/ E3 R; ~ v1 W. P) Y' y& l* DPermission Admin Service规范(Bundle是否许可执行另外的Bundle的代码)% B$ X3 s) e+ K: e6 ^
URL Handlers Service规范(怎样注册URL Schema,如何将java.io.InputStream对象转换为特定的Java对象)
/ L1 p' C2 y) N/ K6 [6 @* ^' qLog Service规范 (以下略。。。)3 |# W/ U7 R% H# M7 I
Configuration Admin Service规范
- ]' }2 x* R- n, ]( X* D: s+ ~Device Access Specification
: i4 X1 |' o! ^$ R! ?User Admin Service Specification) |+ o; R0 ^% ^ D7 A. v8 Q
IO Connector Service Specification
3 C- C" U& y- i. [! l+ wHttp Service Specification9 u9 Z! x0 @ f* `, {$ m
Preference Service Specification
4 A: G# U3 z, x5 PWire Admin Service Specification
0 L, p8 b7 b; g/ z, n, fXML Parser Service Specification8 N3 z$ B$ g5 O+ n8 i) i
Metatype Specification
8 [0 y7 B4 V, ^Service Tracker Specification
; N" M' m5 ~% ~+ D( Z8 R nMeasurment and State Specification
- _. H$ v( q/ HPosition Specification
' F2 r( Y( r; N0 g; b4 VExecution Environment Specfication
9 C9 N& [/ n" \5 n1 f& POSGI Framework( m7 w; u; m5 l; B( o
Framework是OSGI Service Platform规范的核心组成部分。它提供了一个通用的、安全可管理的Java framework。通过这个Framework可以支持一种叫做bundles的Service application的部署和扩展。( T* B4 j0 O# Z2 @) }8 I- n$ Q. f+ }
OSGI兼容设备可以下载并且安装OSGI bundles,也可一当他们不再需要的时候删除。bundles安装后会注册一定数量的Services,并被由同一个Framework下的其他bundles使用。5 |+ _# m: G2 D
在一个动态扩展的的 OSGI环境中,Framework管理bundles的安装和更新。同时也管理bundles和Services之间的依赖关系。
( z' O5 s) @2 J9 aFramework提供给bundle开发者必须的资源来在Java平台上开发,为开发的bundles提供了代码动态加载的功能, 也使得开发者开发、部署一个大规模的Services变的很容易。5 _# I+ n Z) E# _+ K
其 次,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- P7 i& Q& A$ R, x: n
一个一致的编程模型帮助开发者可以应付一些可估计的危急错误。Framework将会运行在不同的硬件环境上,但一致的接口确保软件组建可以运行在一致的服务接口上。' W1 B- S: X! k I8 x" L
The Bundle Object0 S1 h2 k1 }8 l4 J6 x9 X% I
对于每一个安装在OSGI Service Platform的bundle都有一个与之关联的bundle object。一个bundle对象用来管理bundle的生命周期。这项工作通常由Management Agent来做。
6 c9 k2 p( F7 _ u7 g" F5 }5 {. b: |Bundle State
% ^9 r+ n6 k/ P) _bundle有以下状态;
, Y3 ?8 P+ M }4 H% IINSTALLED – The bundle has been successfully installed. Native code clauses must have been validated.2 A) _2 b N0 t7 f, m, 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.
* n O1 s* _# [: [STARTING – The bundle is being started, and the BundleActivato r. start method has been called and has not yet returned.' ]% U! L. s8 L" B0 h4 i6 _! Q" ^# y* z
STOPPING – The bundle is being stopped, and the BundleActivato r. stop method has been called and has not yet returned.
6 F" B, a) N, \ACTIVE – The bundle has successfully started and is running.
" j: l- e9 m9 `6 t5 A+ a. _1 g9 {2 PUNINSTALLED – The bundle has been uninstalled. It cannot move into another state.
% c, q5 ?3 |/ _: ?eclipse 3.0并没有用OSGI替换掉原来的PlugIn机制。它只是做了与标准兼容的工作:给用户提供了一系列的API来访问,在这个过程中,就必须要做一些改 变(比如plugin registry和loading机制)来同OSGI标准完全兼容。最初的Plugin核心只支持静态的扩展,就是说,如果要改变一个已经存在的Plug 就必须重启core,也就是要退出Eclipse并重启。
; S0 s. _# Z& ~3 m7 b' b有很多人问Eclipse为什么要兼容OSGI规范而不是其他的规范呢?
+ p I( z% Y) q3 c+ v$ y) b在 Eclipse被捐赠出来以前,Eclipse由OTI来开发,其目标是开发一个嵌入式Java软件的开发平台。互联网上现在仍然由很多的连接指向 Visual Age Micro Edition (VAME). 这也是SWT被构思的一个原因,他们想将SWT使用在嵌入式设备中的用户界面。这种渊源关系解释了当时为什么选择OSGI规范。$ |9 w$ ]* ]& B# \9 P
另外一个原因是除了OSGI没有其他的规范。OSGI规范在轻量级服务架构应用方面被广泛的支持。而且OSGI被好多电信业的知名公司和一些其他行业的知名公司所支持。他们需要使用OSGI来同Sun的J2ME来抗衡。 |
|