 鲜花( 0)  鸡蛋( 0)
|
OSGi是Open Service Gateway Initiative的简称,该组织建立于1999年,是一个非赢利机构,旨在建立一个开放的服务规范,为通过网络向设备提供服务建立开放的标准。
* V7 c) y5 j1 Y7 Q4 M6 hOSGI 规范包括了构建开放的可交付网络服务的各方面,OSGI规范又包括了以下子规范。
5 _7 Z3 q ]6 KFramework规范(OSGI核心,提供一个安全的可管理的Java Framework来部署可扩展的Java服务。)
* U- ?' q2 ?3 ?5 PPackage Admin Service规范(来管理不同的Bundle之间的引用关系。当Bundle更新或者反安装时判断是否有其他的服务正在使用当前的Bundle)
* ^3 A p8 Y- Q' V& ], P8 p- CStart Level规范(定义了启动和停止一个OSGi Service Platform时,不同的Bundles的启动或者停止的先后顺序)
6 h" U; }$ d/ E7 h5 K, p- H( aPermission Admin Service规范(Bundle是否许可执行另外的Bundle的代码)
& n* G ?1 Z6 j6 C, m) u+ @URL Handlers Service规范(怎样注册URL Schema,如何将java.io.InputStream对象转换为特定的Java对象)% K {# A/ n2 a& J. U
Log Service规范 (以下略。。。)
4 i6 g! G1 R) p5 Z4 k- oConfiguration Admin Service规范
# S- I1 O! E! z# IDevice Access Specification$ k6 g/ }9 C. ] o' ?
User Admin Service Specification6 e' Y# w3 j) ^1 ] g( E; [2 B
IO Connector Service Specification
, M) p$ W8 ]+ L& R s) h1 h: F0 A% F1 qHttp Service Specification5 F! n& Y: s& O& u, P6 j9 V. G% Y
Preference Service Specification$ _1 l% F/ J' i; N$ P
Wire Admin Service Specification; `$ B$ M2 P, ]
XML Parser Service Specification& D. G$ x) P* _4 Z
Metatype Specification
' N- P; W3 C7 X+ g- ~7 j. G- s5 |Service Tracker Specification) q4 g9 k+ x+ L+ r! _
Measurment and State Specification3 c& m8 f- \3 Z u
Position Specification( }, h7 f9 l4 }4 |2 S# a. }( E, Y
Execution Environment Specfication! \9 i2 v2 h3 ~
OSGI Framework
- Y" [, p1 `/ }- ?6 W- z% DFramework是OSGI Service Platform规范的核心组成部分。它提供了一个通用的、安全可管理的Java framework。通过这个Framework可以支持一种叫做bundles的Service application的部署和扩展。
% L1 ]% x- g* p7 ~ W' MOSGI兼容设备可以下载并且安装OSGI bundles,也可一当他们不再需要的时候删除。bundles安装后会注册一定数量的Services,并被由同一个Framework下的其他bundles使用。
/ a) c1 [# L, t5 z! a0 K7 ^7 e在一个动态扩展的的 OSGI环境中,Framework管理bundles的安装和更新。同时也管理bundles和Services之间的依赖关系。; l9 ~/ b" m2 `0 K5 T1 K8 Y/ F
Framework提供给bundle开发者必须的资源来在Java平台上开发,为开发的bundles提供了代码动态加载的功能, 也使得开发者开发、部署一个大规模的Services变的很容易。1 p. w) ^- X/ _" 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.' R" X4 ~+ o* |$ K1 s( P7 x2 P i( ^
一个一致的编程模型帮助开发者可以应付一些可估计的危急错误。Framework将会运行在不同的硬件环境上,但一致的接口确保软件组建可以运行在一致的服务接口上。
9 ]2 Z% i4 R y$ v( b' }The Bundle Object P2 @! @$ O3 P5 W; ]" u; E- x
对于每一个安装在OSGI Service Platform的bundle都有一个与之关联的bundle object。一个bundle对象用来管理bundle的生命周期。这项工作通常由Management Agent来做。& _) \$ A/ c/ ~& R2 R
Bundle State
& {* w. f. J! v% D8 b+ g. k# Q1 Ybundle有以下状态;0 D& U% n7 N% P! j" y
INSTALLED – The bundle has been successfully installed. Native code clauses must have been validated.
( D' ?" d1 a/ }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.( p3 _- z1 l/ X7 [% H7 y5 ?
STARTING – The bundle is being started, and the BundleActivato r. start method has been called and has not yet returned. @6 F" [" q# x% [: d0 B; k8 y
STOPPING – The bundle is being stopped, and the BundleActivato r. stop method has been called and has not yet returned.5 t5 }3 o7 g& N8 j1 @ F+ ?
ACTIVE – The bundle has successfully started and is running.
5 U) b x; R' a( }$ DUNINSTALLED – The bundle has been uninstalled. It cannot move into another state.
% @7 J7 u* m% N, ?2 Yeclipse 3.0并没有用OSGI替换掉原来的PlugIn机制。它只是做了与标准兼容的工作:给用户提供了一系列的API来访问,在这个过程中,就必须要做一些改 变(比如plugin registry和loading机制)来同OSGI标准完全兼容。最初的Plugin核心只支持静态的扩展,就是说,如果要改变一个已经存在的Plug 就必须重启core,也就是要退出Eclipse并重启。* g$ H; c6 _3 Q' T) w6 Z
有很多人问Eclipse为什么要兼容OSGI规范而不是其他的规范呢?
/ v( F% P5 Q$ C1 V' c# P: d5 c3 V在 Eclipse被捐赠出来以前,Eclipse由OTI来开发,其目标是开发一个嵌入式Java软件的开发平台。互联网上现在仍然由很多的连接指向 Visual Age Micro Edition (VAME). 这也是SWT被构思的一个原因,他们想将SWT使用在嵌入式设备中的用户界面。这种渊源关系解释了当时为什么选择OSGI规范。# k p3 n5 U/ f9 P7 s4 q2 L
另外一个原因是除了OSGI没有其他的规范。OSGI规范在轻量级服务架构应用方面被广泛的支持。而且OSGI被好多电信业的知名公司和一些其他行业的知名公司所支持。他们需要使用OSGI来同Sun的J2ME来抗衡。 |
|