 鲜花( 0)  鸡蛋( 0)
|
OSGi是Open Service Gateway Initiative的简称,该组织建立于1999年,是一个非赢利机构,旨在建立一个开放的服务规范,为通过网络向设备提供服务建立开放的标准。
% Y! F. c, b" w- A* Q* R# S7 }OSGI 规范包括了构建开放的可交付网络服务的各方面,OSGI规范又包括了以下子规范。
9 S9 w8 ]" u6 |2 ?- i( X" Y7 [Framework规范(OSGI核心,提供一个安全的可管理的Java Framework来部署可扩展的Java服务。)
& _& f+ K& x) N' D [. |8 r' BPackage Admin Service规范(来管理不同的Bundle之间的引用关系。当Bundle更新或者反安装时判断是否有其他的服务正在使用当前的Bundle)$ Q! |& B& ^% }/ n
Start Level规范(定义了启动和停止一个OSGi Service Platform时,不同的Bundles的启动或者停止的先后顺序)
% y; ]9 {& R6 C+ f0 }, }0 T! @Permission Admin Service规范(Bundle是否许可执行另外的Bundle的代码)0 t9 c0 l2 T w' Z! {
URL Handlers Service规范(怎样注册URL Schema,如何将java.io.InputStream对象转换为特定的Java对象)
# B" I4 }2 ^. m$ VLog Service规范 (以下略。。。)
1 @" p1 ~7 v+ h& ` c0 D% TConfiguration Admin Service规范
" k! u; j; x3 B* eDevice Access Specification! m4 t k/ i* m/ d1 G
User Admin Service Specification
* Z! u: k7 a; B& XIO Connector Service Specification$ q: q1 n$ M! W X! G; a5 U) L6 O
Http Service Specification1 R y/ O/ H. R8 `: q; ^
Preference Service Specification
. G! k8 E) o7 E5 H7 U2 l6 {; jWire Admin Service Specification4 X- |# k4 J V
XML Parser Service Specification, a( d. O9 }& c2 y P' q
Metatype Specification
4 k/ M: @3 A+ p8 v4 z& f* jService Tracker Specification
5 W% S; E2 C- R) `" ^Measurment and State Specification4 S3 H* A. k/ d* `' p
Position Specification
) I" n7 M8 W3 K1 `& jExecution Environment Specfication G1 O9 N' I; b4 b* y+ V
OSGI Framework
2 M+ M; e3 j' {1 v' W6 TFramework是OSGI Service Platform规范的核心组成部分。它提供了一个通用的、安全可管理的Java framework。通过这个Framework可以支持一种叫做bundles的Service application的部署和扩展。
' b- C( ]. q1 ^. ]+ ^( ~OSGI兼容设备可以下载并且安装OSGI bundles,也可一当他们不再需要的时候删除。bundles安装后会注册一定数量的Services,并被由同一个Framework下的其他bundles使用。7 r0 E- n# N2 I5 L- P% X7 D+ G
在一个动态扩展的的 OSGI环境中,Framework管理bundles的安装和更新。同时也管理bundles和Services之间的依赖关系。* v- @( @2 |; ~5 w
Framework提供给bundle开发者必须的资源来在Java平台上开发,为开发的bundles提供了代码动态加载的功能, 也使得开发者开发、部署一个大规模的Services变的很容易。
4 f3 S* T1 s8 M2 ?. s0 D其 次,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+ c7 ]- m+ e8 b! \一个一致的编程模型帮助开发者可以应付一些可估计的危急错误。Framework将会运行在不同的硬件环境上,但一致的接口确保软件组建可以运行在一致的服务接口上。
% S0 o5 S8 c3 `' x7 L$ ]8 T3 T0 I/ HThe Bundle Object. `4 d$ _- a: _; h, ?) i
对于每一个安装在OSGI Service Platform的bundle都有一个与之关联的bundle object。一个bundle对象用来管理bundle的生命周期。这项工作通常由Management Agent来做。! p9 J5 R: ?5 l( W9 F
Bundle State1 K; x- {$ Z: I6 n2 ?% p! K9 d' g
bundle有以下状态;7 H: l. g" I7 H. i) ~. W7 p% t+ l
INSTALLED – The bundle has been successfully installed. Native code clauses must have been validated.
' ^ g3 Q; F, K" {5 B& x, [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.
6 R+ l: h$ R: a. XSTARTING – The bundle is being started, and the BundleActivato r. start method has been called and has not yet returned.) E( ^# C4 m! [' g0 O# x
STOPPING – The bundle is being stopped, and the BundleActivato r. stop method has been called and has not yet returned.8 |# f9 ?- [( I1 B
ACTIVE – The bundle has successfully started and is running.! Q- O2 h3 [! j1 k9 |1 b
UNINSTALLED – The bundle has been uninstalled. It cannot move into another state.8 v) T I. d: f- `
eclipse 3.0并没有用OSGI替换掉原来的PlugIn机制。它只是做了与标准兼容的工作:给用户提供了一系列的API来访问,在这个过程中,就必须要做一些改 变(比如plugin registry和loading机制)来同OSGI标准完全兼容。最初的Plugin核心只支持静态的扩展,就是说,如果要改变一个已经存在的Plug 就必须重启core,也就是要退出Eclipse并重启。/ l# b! D8 j/ W5 p( i% F6 A
有很多人问Eclipse为什么要兼容OSGI规范而不是其他的规范呢?/ ?& |8 i2 o6 q( L; F" R# J
在 Eclipse被捐赠出来以前,Eclipse由OTI来开发,其目标是开发一个嵌入式Java软件的开发平台。互联网上现在仍然由很多的连接指向 Visual Age Micro Edition (VAME). 这也是SWT被构思的一个原因,他们想将SWT使用在嵌入式设备中的用户界面。这种渊源关系解释了当时为什么选择OSGI规范。7 |2 x/ E$ I/ k d, }
另外一个原因是除了OSGI没有其他的规范。OSGI规范在轻量级服务架构应用方面被广泛的支持。而且OSGI被好多电信业的知名公司和一些其他行业的知名公司所支持。他们需要使用OSGI来同Sun的J2ME来抗衡。 |
|