 鲜花( 0)  鸡蛋( 0)
|
OSGi是Open Service Gateway Initiative的简称,该组织建立于1999年,是一个非赢利机构,旨在建立一个开放的服务规范,为通过网络向设备提供服务建立开放的标准。
+ ^, u/ n5 f6 _3 SOSGI 规范包括了构建开放的可交付网络服务的各方面,OSGI规范又包括了以下子规范。
& k, | x$ k3 P) B$ tFramework规范(OSGI核心,提供一个安全的可管理的Java Framework来部署可扩展的Java服务。)
7 I% r) d3 B+ ~# x5 |Package Admin Service规范(来管理不同的Bundle之间的引用关系。当Bundle更新或者反安装时判断是否有其他的服务正在使用当前的Bundle)
2 a" R& y6 k% D! Y. A. N) DStart Level规范(定义了启动和停止一个OSGi Service Platform时,不同的Bundles的启动或者停止的先后顺序)- F+ ~$ W+ @, Q
Permission Admin Service规范(Bundle是否许可执行另外的Bundle的代码)
$ X5 d n; }5 }% R" KURL Handlers Service规范(怎样注册URL Schema,如何将java.io.InputStream对象转换为特定的Java对象)
b6 _' M- k, _1 _2 ]Log Service规范 (以下略。。。) u, F: ~ r5 j- h/ ?6 c
Configuration Admin Service规范1 i* x' U4 w/ e) y f2 L
Device Access Specification8 m2 P, B5 o$ g$ e* I! q
User Admin Service Specification
# l' J& Z) o) P+ \0 z/ JIO Connector Service Specification9 A! Z# d4 z$ b( _5 }. X' S( K. f
Http Service Specification f& f E f' w! ~) V, B
Preference Service Specification
( x3 `0 L1 N2 D0 D0 QWire Admin Service Specification
) \9 y }+ o! X* QXML Parser Service Specification" _/ \# a/ W4 c/ g% ?
Metatype Specification2 D7 N9 h! R9 q. R
Service Tracker Specification
' j' z5 d/ F! m) i6 y$ t0 U5 nMeasurment and State Specification
* T1 J- m) e; n- n2 d9 kPosition Specification
- F8 z4 c5 n. e- P( MExecution Environment Specfication5 b+ b# V% v0 c. ]
OSGI Framework
7 @% c% q( b! iFramework是OSGI Service Platform规范的核心组成部分。它提供了一个通用的、安全可管理的Java framework。通过这个Framework可以支持一种叫做bundles的Service application的部署和扩展。
* ?9 c. c) J9 tOSGI兼容设备可以下载并且安装OSGI bundles,也可一当他们不再需要的时候删除。bundles安装后会注册一定数量的Services,并被由同一个Framework下的其他bundles使用。
9 }# Z4 p: v) g; h1 y' P5 ~在一个动态扩展的的 OSGI环境中,Framework管理bundles的安装和更新。同时也管理bundles和Services之间的依赖关系。
1 `' f; y9 r, g3 m$ U7 mFramework提供给bundle开发者必须的资源来在Java平台上开发,为开发的bundles提供了代码动态加载的功能, 也使得开发者开发、部署一个大规模的Services变的很容易。
- Z- ^# t8 K9 X6 x; t. e, W其 次,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.0 F6 f- J/ T# D
一个一致的编程模型帮助开发者可以应付一些可估计的危急错误。Framework将会运行在不同的硬件环境上,但一致的接口确保软件组建可以运行在一致的服务接口上。
. {0 Y* ^- \% Q# \The Bundle Object
. v5 E( `# m+ c" f2 g( W9 y对于每一个安装在OSGI Service Platform的bundle都有一个与之关联的bundle object。一个bundle对象用来管理bundle的生命周期。这项工作通常由Management Agent来做。4 l% A8 B+ \ ]5 _8 z
Bundle State
- V) V3 F6 E0 G! R7 C7 cbundle有以下状态;+ X% Q: |% ]1 F L: E
INSTALLED – The bundle has been successfully installed. Native code clauses must have been validated.6 u+ C/ e) R; S, T, B) p
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.
. ~! C& c' Y9 E! E- }' ESTARTING – The bundle is being started, and the BundleActivato r. start method has been called and has not yet returned.& g. ^: u. p3 \9 G
STOPPING – The bundle is being stopped, and the BundleActivato r. stop method has been called and has not yet returned.
8 Z; \: X1 E& n+ c' l2 `4 D3 L6 G' vACTIVE – The bundle has successfully started and is running.
0 W7 P. Y+ g% `9 @3 pUNINSTALLED – The bundle has been uninstalled. It cannot move into another state.- ^+ G- d! v6 j4 Y- D& B% ^& K
eclipse 3.0并没有用OSGI替换掉原来的PlugIn机制。它只是做了与标准兼容的工作:给用户提供了一系列的API来访问,在这个过程中,就必须要做一些改 变(比如plugin registry和loading机制)来同OSGI标准完全兼容。最初的Plugin核心只支持静态的扩展,就是说,如果要改变一个已经存在的Plug 就必须重启core,也就是要退出Eclipse并重启。$ L! g3 I0 _% z( d* Q' ?
有很多人问Eclipse为什么要兼容OSGI规范而不是其他的规范呢?
$ I* T4 D7 o/ ]; ^2 ~; L+ L. M0 C, ^在 Eclipse被捐赠出来以前,Eclipse由OTI来开发,其目标是开发一个嵌入式Java软件的开发平台。互联网上现在仍然由很多的连接指向 Visual Age Micro Edition (VAME). 这也是SWT被构思的一个原因,他们想将SWT使用在嵌入式设备中的用户界面。这种渊源关系解释了当时为什么选择OSGI规范。
2 h. ]. o# `- f: o J6 T! X另外一个原因是除了OSGI没有其他的规范。OSGI规范在轻量级服务架构应用方面被广泛的支持。而且OSGI被好多电信业的知名公司和一些其他行业的知名公司所支持。他们需要使用OSGI来同Sun的J2ME来抗衡。 |
|