 鲜花( 0)  鸡蛋( 0)
|
OSGi是Open Service Gateway Initiative的简称,该组织建立于1999年,是一个非赢利机构,旨在建立一个开放的服务规范,为通过网络向设备提供服务建立开放的标准。 K( O( @% @& v1 @
OSGI 规范包括了构建开放的可交付网络服务的各方面,OSGI规范又包括了以下子规范。
8 H4 Y$ C, M5 e# E( S6 C# hFramework规范(OSGI核心,提供一个安全的可管理的Java Framework来部署可扩展的Java服务。)
\' y$ S8 n, }, O2 Q! q6 ^0 d+ B& O1 `Package Admin Service规范(来管理不同的Bundle之间的引用关系。当Bundle更新或者反安装时判断是否有其他的服务正在使用当前的Bundle)
* ]# ^8 n. c' `, [/ L9 k& \Start Level规范(定义了启动和停止一个OSGi Service Platform时,不同的Bundles的启动或者停止的先后顺序)
1 Y1 C7 z9 W! j8 O* q1 c1 fPermission Admin Service规范(Bundle是否许可执行另外的Bundle的代码)
- v; Y/ c+ B4 P% HURL Handlers Service规范(怎样注册URL Schema,如何将java.io.InputStream对象转换为特定的Java对象)$ a8 m6 E8 l) |
Log Service规范 (以下略。。。)
" J; A7 K- R% A5 i3 B; X/ F! r+ K$ EConfiguration Admin Service规范
! R# F3 U X6 t8 N4 i+ xDevice Access Specification+ m4 U" {, S" @, ]& D1 Q9 @' h; [
User Admin Service Specification
! o5 u# a, |1 g% AIO Connector Service Specification
. G5 Q- V1 O% u2 u& z/ A) vHttp Service Specification
; S, v* Z- O3 Y, K9 j! CPreference Service Specification9 L7 B8 |' i; O
Wire Admin Service Specification1 t8 H8 j; O5 S; y) V
XML Parser Service Specification
9 P. }! L3 I: V6 lMetatype Specification9 f o; L' z+ F$ a) r% y1 E m
Service Tracker Specification
3 n3 U! Z {' ZMeasurment and State Specification
* |7 j0 p. ?) j, h+ S4 HPosition Specification
8 g7 F" R4 @5 V) b! f3 Y! YExecution Environment Specfication
$ _# y0 h! C r. COSGI Framework/ j& c/ x2 G1 T* u6 z3 @5 h4 E
Framework是OSGI Service Platform规范的核心组成部分。它提供了一个通用的、安全可管理的Java framework。通过这个Framework可以支持一种叫做bundles的Service application的部署和扩展。
b/ d/ ]/ M4 w3 eOSGI兼容设备可以下载并且安装OSGI bundles,也可一当他们不再需要的时候删除。bundles安装后会注册一定数量的Services,并被由同一个Framework下的其他bundles使用。1 a+ V% h5 G3 H4 Z q
在一个动态扩展的的 OSGI环境中,Framework管理bundles的安装和更新。同时也管理bundles和Services之间的依赖关系。/ g' Z5 L! c5 W+ ]9 I
Framework提供给bundle开发者必须的资源来在Java平台上开发,为开发的bundles提供了代码动态加载的功能, 也使得开发者开发、部署一个大规模的Services变的很容易。
( |0 A# \" H+ l% K- L其 次,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.% A. {2 C6 i3 e; s6 ]
一个一致的编程模型帮助开发者可以应付一些可估计的危急错误。Framework将会运行在不同的硬件环境上,但一致的接口确保软件组建可以运行在一致的服务接口上。 O: S; _, }/ C( M/ j# C
The Bundle Object7 ` t) n0 o1 M4 \+ n
对于每一个安装在OSGI Service Platform的bundle都有一个与之关联的bundle object。一个bundle对象用来管理bundle的生命周期。这项工作通常由Management Agent来做。
, T, t+ r3 I, c0 w( W3 m5 XBundle State7 J* {) K" [9 m8 ~7 [. A* {
bundle有以下状态;' j O/ z5 q& u+ I
INSTALLED – The bundle has been successfully installed. Native code clauses must have been validated. b8 | F, ^9 C# t( C9 B
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.: z* M4 Z n/ e7 W- [
STARTING – The bundle is being started, and the BundleActivato r. start method has been called and has not yet returned.
: i5 S5 K6 b* }* rSTOPPING – The bundle is being stopped, and the BundleActivato r. stop method has been called and has not yet returned.! }5 \; u9 h' I: z) ^1 v. N
ACTIVE – The bundle has successfully started and is running.) U% _# q3 o: M6 J
UNINSTALLED – The bundle has been uninstalled. It cannot move into another state.' y9 h m* C5 A" [; E- K+ a! M
eclipse 3.0并没有用OSGI替换掉原来的PlugIn机制。它只是做了与标准兼容的工作:给用户提供了一系列的API来访问,在这个过程中,就必须要做一些改 变(比如plugin registry和loading机制)来同OSGI标准完全兼容。最初的Plugin核心只支持静态的扩展,就是说,如果要改变一个已经存在的Plug 就必须重启core,也就是要退出Eclipse并重启。% H( e; ^4 I% m5 \# {, x3 H$ a8 D
有很多人问Eclipse为什么要兼容OSGI规范而不是其他的规范呢?4 z. s: g- C. c7 ~; N: C% S
在 Eclipse被捐赠出来以前,Eclipse由OTI来开发,其目标是开发一个嵌入式Java软件的开发平台。互联网上现在仍然由很多的连接指向 Visual Age Micro Edition (VAME). 这也是SWT被构思的一个原因,他们想将SWT使用在嵌入式设备中的用户界面。这种渊源关系解释了当时为什么选择OSGI规范。# C3 a. q5 l! ?$ {+ @8 R# r
另外一个原因是除了OSGI没有其他的规范。OSGI规范在轻量级服务架构应用方面被广泛的支持。而且OSGI被好多电信业的知名公司和一些其他行业的知名公司所支持。他们需要使用OSGI来同Sun的J2ME来抗衡。 |
|