 鲜花( 0)  鸡蛋( 0)
|
OSGi是Open Service Gateway Initiative的简称,该组织建立于1999年,是一个非赢利机构,旨在建立一个开放的服务规范,为通过网络向设备提供服务建立开放的标准。
& Q0 U$ {. |0 y. H3 UOSGI 规范包括了构建开放的可交付网络服务的各方面,OSGI规范又包括了以下子规范。 " Y, N8 v7 ~* r+ O6 L
Framework规范(OSGI核心,提供一个安全的可管理的Java Framework来部署可扩展的Java服务。) & k \8 x3 Y) U: r% t! H
Package Admin Service规范(来管理不同的Bundle之间的引用关系。当Bundle更新或者反安装时判断是否有其他的服务正在使用当前的Bundle)
: n0 s7 M' h8 S$ g B- l# mStart Level规范(定义了启动和停止一个OSGi Service Platform时,不同的Bundles的启动或者停止的先后顺序)
" k8 i$ k' C& X. Q* ^Permission Admin Service规范(Bundle是否许可执行另外的Bundle的代码)/ s: b% A8 a( Y4 V+ M" a% c0 s
URL Handlers Service规范(怎样注册URL Schema,如何将java.io.InputStream对象转换为特定的Java对象)2 T# x; e( K- b* x4 Y" _3 \0 b
Log Service规范 (以下略。。。)
' Q( b6 ~6 v5 k- dConfiguration Admin Service规范
4 b9 w" q& ~; ]5 C' a4 j, P7 g) XDevice Access Specification
% I+ h0 A' G; J4 G+ N9 ~User Admin Service Specification
# M d: ~3 Z. A8 PIO Connector Service Specification
& l9 z$ N" p* a. o/ eHttp Service Specification" _- n( |& a7 d3 K/ ^9 }% J
Preference Service Specification5 k; B' [2 ~0 n1 S8 l$ J
Wire Admin Service Specification( `9 |0 _. x# m! V' `
XML Parser Service Specification
6 W9 ~ Q# M% q4 t$ G1 n3 Y" AMetatype Specification* d [( U# r; @7 L) j0 K6 n7 u
Service Tracker Specification
! t% l# M" e. K2 {/ Q: c& UMeasurment and State Specification$ ]! F7 B. c) u( N
Position Specification9 c5 o/ ^- M* z) a! h) \: u* a5 p
Execution Environment Specfication
0 s. D3 f z" Y9 JOSGI Framework
: Q1 [9 J! n8 [8 L. I' C# bFramework是OSGI Service Platform规范的核心组成部分。它提供了一个通用的、安全可管理的Java framework。通过这个Framework可以支持一种叫做bundles的Service application的部署和扩展。! m, D- @$ O. q r# r' F
OSGI兼容设备可以下载并且安装OSGI bundles,也可一当他们不再需要的时候删除。bundles安装后会注册一定数量的Services,并被由同一个Framework下的其他bundles使用。
& P6 }/ T" [7 @" @) H( r在一个动态扩展的的 OSGI环境中,Framework管理bundles的安装和更新。同时也管理bundles和Services之间的依赖关系。
2 L4 {3 i Y3 x" ~% ^4 ^9 HFramework提供给bundle开发者必须的资源来在Java平台上开发,为开发的bundles提供了代码动态加载的功能, 也使得开发者开发、部署一个大规模的Services变的很容易。" K& d2 v; n* \; q7 v
其 次,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.
+ L0 K5 r+ ]/ W$ y+ z一个一致的编程模型帮助开发者可以应付一些可估计的危急错误。Framework将会运行在不同的硬件环境上,但一致的接口确保软件组建可以运行在一致的服务接口上。
7 x0 Q1 p$ x( OThe Bundle Object. R& {* u5 F- ?! L M) z. E
对于每一个安装在OSGI Service Platform的bundle都有一个与之关联的bundle object。一个bundle对象用来管理bundle的生命周期。这项工作通常由Management Agent来做。
; j' d0 @$ p9 R9 c, N, ?1 sBundle State
I3 L7 j: Q, u/ }bundle有以下状态;. D' ] i9 A$ j$ h
INSTALLED – The bundle has been successfully installed. Native code clauses must have been validated.5 y1 U$ @/ Q0 x" t
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.2 {8 ]. {( A. |% C9 D6 N: C
STARTING – The bundle is being started, and the BundleActivato r. start method has been called and has not yet returned.
' n& r' f/ Q4 N7 ~- S' u2 ^; ?STOPPING – The bundle is being stopped, and the BundleActivato r. stop method has been called and has not yet returned.8 ]9 u; I# y$ ^5 e+ M) `+ ~1 K
ACTIVE – The bundle has successfully started and is running.
2 L5 o# H+ ^! _5 sUNINSTALLED – The bundle has been uninstalled. It cannot move into another state.
) {, b9 I8 u9 h9 Eeclipse 3.0并没有用OSGI替换掉原来的PlugIn机制。它只是做了与标准兼容的工作:给用户提供了一系列的API来访问,在这个过程中,就必须要做一些改 变(比如plugin registry和loading机制)来同OSGI标准完全兼容。最初的Plugin核心只支持静态的扩展,就是说,如果要改变一个已经存在的Plug 就必须重启core,也就是要退出Eclipse并重启。
( R3 J, u% ^* e* L1 N# Y; h- i9 `2 D有很多人问Eclipse为什么要兼容OSGI规范而不是其他的规范呢?5 s! b0 u }) t( s, T
在 Eclipse被捐赠出来以前,Eclipse由OTI来开发,其目标是开发一个嵌入式Java软件的开发平台。互联网上现在仍然由很多的连接指向 Visual Age Micro Edition (VAME). 这也是SWT被构思的一个原因,他们想将SWT使用在嵌入式设备中的用户界面。这种渊源关系解释了当时为什么选择OSGI规范。% ?7 g2 }1 e: L1 ~5 j& |) |
另外一个原因是除了OSGI没有其他的规范。OSGI规范在轻量级服务架构应用方面被广泛的支持。而且OSGI被好多电信业的知名公司和一些其他行业的知名公司所支持。他们需要使用OSGI来同Sun的J2ME来抗衡。 |
|