 鲜花( 0)  鸡蛋( 0)
|
OSGi是Open Service Gateway Initiative的简称,该组织建立于1999年,是一个非赢利机构,旨在建立一个开放的服务规范,为通过网络向设备提供服务建立开放的标准。* o6 @6 \( y" c) I
OSGI 规范包括了构建开放的可交付网络服务的各方面,OSGI规范又包括了以下子规范。
5 ^; `& [$ L, d& p4 c. a+ @Framework规范(OSGI核心,提供一个安全的可管理的Java Framework来部署可扩展的Java服务。) 1 h% {; }# t2 L" e7 I5 ?* Q, [6 E$ u
Package Admin Service规范(来管理不同的Bundle之间的引用关系。当Bundle更新或者反安装时判断是否有其他的服务正在使用当前的Bundle)
% V7 a+ ]# D$ C% @' h, YStart Level规范(定义了启动和停止一个OSGi Service Platform时,不同的Bundles的启动或者停止的先后顺序)
" \7 f! ?2 U4 {" BPermission Admin Service规范(Bundle是否许可执行另外的Bundle的代码)
% C' a: Q! T' PURL Handlers Service规范(怎样注册URL Schema,如何将java.io.InputStream对象转换为特定的Java对象)0 J' I1 O4 T; E6 D( T/ z+ m9 J& Q. w
Log Service规范 (以下略。。。)& F x' \3 K# I0 x
Configuration Admin Service规范3 ?8 C: \- n& Y7 Y# x D
Device Access Specification! d; W3 P! s J& I% S O
User Admin Service Specification
" a% H; `8 S; ^7 hIO Connector Service Specification
- H. p, Y5 I1 M" D' R$ eHttp Service Specification
* ^0 g9 K; W P: d% g% `Preference Service Specification
# k# a3 R& m5 h8 V( K3 ?6 d: S. @Wire Admin Service Specification+ Z# S' I) r6 w+ g7 K& L! P* C
XML Parser Service Specification
$ F; H" g3 `3 z1 h1 R/ {Metatype Specification
0 X7 B& O2 `1 g/ EService Tracker Specification
# ~2 x7 |' G. j$ x" c, A h; PMeasurment and State Specification
. v' R! ]3 ?5 ?/ j8 X" kPosition Specification/ R/ J y/ S& d$ E/ x$ j
Execution Environment Specfication
8 G8 D$ p N& \ cOSGI Framework
4 M% v" J6 g4 f& y& ^Framework是OSGI Service Platform规范的核心组成部分。它提供了一个通用的、安全可管理的Java framework。通过这个Framework可以支持一种叫做bundles的Service application的部署和扩展。
+ P- h+ f& T t& o& y. k% n, eOSGI兼容设备可以下载并且安装OSGI bundles,也可一当他们不再需要的时候删除。bundles安装后会注册一定数量的Services,并被由同一个Framework下的其他bundles使用。3 V o+ j* u$ Z* e0 |
在一个动态扩展的的 OSGI环境中,Framework管理bundles的安装和更新。同时也管理bundles和Services之间的依赖关系。
1 n0 \! M c$ G6 L, P5 SFramework提供给bundle开发者必须的资源来在Java平台上开发,为开发的bundles提供了代码动态加载的功能, 也使得开发者开发、部署一个大规模的Services变的很容易。
0 S$ Z% D" N7 A& n1 Q; R" e/ T! a其 次,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.
, l/ u3 z; [! ^一个一致的编程模型帮助开发者可以应付一些可估计的危急错误。Framework将会运行在不同的硬件环境上,但一致的接口确保软件组建可以运行在一致的服务接口上。$ m; l1 H! [( B8 p | N
The Bundle Object( F9 n* |* K+ l; {! O P* S& l
对于每一个安装在OSGI Service Platform的bundle都有一个与之关联的bundle object。一个bundle对象用来管理bundle的生命周期。这项工作通常由Management Agent来做。: V3 b% t" {6 T+ P0 d& e& ?
Bundle State
& d( N2 o2 R* L/ ?7 ?bundle有以下状态;
- f/ j8 n6 ]+ l: {; t+ Y! s. V" y: rINSTALLED – The bundle has been successfully installed. Native code clauses must have been validated.) l/ Q; X0 g- v& z- h+ q! v' S
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.0 ^. e4 V6 q2 a3 G" |7 U* g g
STARTING – The bundle is being started, and the BundleActivato r. start method has been called and has not yet returned.
4 }/ V# v& U+ y4 T1 D2 M/ HSTOPPING – The bundle is being stopped, and the BundleActivato r. stop method has been called and has not yet returned.
, f9 s4 Z) R+ J, D. R+ [ACTIVE – The bundle has successfully started and is running.8 a0 ]" E' Z; O7 k3 j8 w
UNINSTALLED – The bundle has been uninstalled. It cannot move into another state.
; c/ A) x6 C7 A- ^eclipse 3.0并没有用OSGI替换掉原来的PlugIn机制。它只是做了与标准兼容的工作:给用户提供了一系列的API来访问,在这个过程中,就必须要做一些改 变(比如plugin registry和loading机制)来同OSGI标准完全兼容。最初的Plugin核心只支持静态的扩展,就是说,如果要改变一个已经存在的Plug 就必须重启core,也就是要退出Eclipse并重启。8 X% V8 H" B; g
有很多人问Eclipse为什么要兼容OSGI规范而不是其他的规范呢?
+ x5 D7 U+ I1 ?2 E$ m( O7 O在 Eclipse被捐赠出来以前,Eclipse由OTI来开发,其目标是开发一个嵌入式Java软件的开发平台。互联网上现在仍然由很多的连接指向 Visual Age Micro Edition (VAME). 这也是SWT被构思的一个原因,他们想将SWT使用在嵌入式设备中的用户界面。这种渊源关系解释了当时为什么选择OSGI规范。$ X9 O8 v7 H, Q8 o; ?" b
另外一个原因是除了OSGI没有其他的规范。OSGI规范在轻量级服务架构应用方面被广泛的支持。而且OSGI被好多电信业的知名公司和一些其他行业的知名公司所支持。他们需要使用OSGI来同Sun的J2ME来抗衡。 |
|