 鲜花( 0)  鸡蛋( 0)
|
OSGi是Open Service Gateway Initiative的简称,该组织建立于1999年,是一个非赢利机构,旨在建立一个开放的服务规范,为通过网络向设备提供服务建立开放的标准。
7 [( H! h! n( y! NOSGI 规范包括了构建开放的可交付网络服务的各方面,OSGI规范又包括了以下子规范。
6 O' F+ R0 R- ~+ UFramework规范(OSGI核心,提供一个安全的可管理的Java Framework来部署可扩展的Java服务。) 6 o$ d& k7 o- {
Package Admin Service规范(来管理不同的Bundle之间的引用关系。当Bundle更新或者反安装时判断是否有其他的服务正在使用当前的Bundle)
& `+ v; ^- F; U& P' y! z) w7 j5 BStart Level规范(定义了启动和停止一个OSGi Service Platform时,不同的Bundles的启动或者停止的先后顺序)
$ M6 H6 h0 E; i: d/ FPermission Admin Service规范(Bundle是否许可执行另外的Bundle的代码)
8 [2 u3 w& x* l. e8 J! j3 NURL Handlers Service规范(怎样注册URL Schema,如何将java.io.InputStream对象转换为特定的Java对象)
4 ~' a ^, i# I8 S' cLog Service规范 (以下略。。。)& Y% s# m$ v+ _2 n" l1 o C2 e! s3 R
Configuration Admin Service规范5 l0 I7 Y- r8 ]; U' ]
Device Access Specification0 {+ O/ g3 x% @, Z
User Admin Service Specification
" D, I( F) t1 z( I6 Y7 XIO Connector Service Specification1 u2 l" p# w0 r# t9 a
Http Service Specification% I* Z/ V, \, [8 o+ Y
Preference Service Specification: V/ M' N9 {; _% u
Wire Admin Service Specification
0 r1 M$ H0 O# c: q4 XXML Parser Service Specification% J) N: h* a F& X5 `
Metatype Specification
& K( m' I8 R$ h- Y3 z! e; v$ F' s% KService Tracker Specification# m6 n2 ~8 }9 h
Measurment and State Specification0 U! W! U( |) g4 j
Position Specification
- x; t1 D! C) p7 @- }5 t+ MExecution Environment Specfication
/ [6 J2 }6 |( Y: _, t4 @; ?OSGI Framework6 ~& `# k/ V. N3 G% t( o+ n8 q
Framework是OSGI Service Platform规范的核心组成部分。它提供了一个通用的、安全可管理的Java framework。通过这个Framework可以支持一种叫做bundles的Service application的部署和扩展。
, x1 l# h# L4 d, W9 D$ \OSGI兼容设备可以下载并且安装OSGI bundles,也可一当他们不再需要的时候删除。bundles安装后会注册一定数量的Services,并被由同一个Framework下的其他bundles使用。! D- Q4 ^% j& J# v
在一个动态扩展的的 OSGI环境中,Framework管理bundles的安装和更新。同时也管理bundles和Services之间的依赖关系。
( E' W1 E. c4 s( u$ eFramework提供给bundle开发者必须的资源来在Java平台上开发,为开发的bundles提供了代码动态加载的功能, 也使得开发者开发、部署一个大规模的Services变的很容易。$ E v- B8 z' G% h T$ w1 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.
5 s) ]8 g& s+ \$ _一个一致的编程模型帮助开发者可以应付一些可估计的危急错误。Framework将会运行在不同的硬件环境上,但一致的接口确保软件组建可以运行在一致的服务接口上。
8 X7 V5 S) a6 {7 z8 A9 { CThe Bundle Object; B7 T$ x0 E/ b0 e! L
对于每一个安装在OSGI Service Platform的bundle都有一个与之关联的bundle object。一个bundle对象用来管理bundle的生命周期。这项工作通常由Management Agent来做。" z, B' g0 Z! W! K' m
Bundle State
+ g0 |$ j: [0 K; nbundle有以下状态;
; q0 G: S. @% r8 EINSTALLED – The bundle has been successfully installed. Native code clauses must have been validated.$ V% b9 h( h/ O5 z: J9 ] o
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.
7 S( E( b$ u1 aSTARTING – The bundle is being started, and the BundleActivato r. start method has been called and has not yet returned./ c/ Z. O% T: r5 ?" S7 p
STOPPING – The bundle is being stopped, and the BundleActivato r. stop method has been called and has not yet returned.
7 f5 |# A% s# b1 R% X( _% NACTIVE – The bundle has successfully started and is running.. q' I! h* D& ^7 E4 J6 H. Y& h
UNINSTALLED – The bundle has been uninstalled. It cannot move into another state.5 t& F. N% J! m6 t% U0 V
eclipse 3.0并没有用OSGI替换掉原来的PlugIn机制。它只是做了与标准兼容的工作:给用户提供了一系列的API来访问,在这个过程中,就必须要做一些改 变(比如plugin registry和loading机制)来同OSGI标准完全兼容。最初的Plugin核心只支持静态的扩展,就是说,如果要改变一个已经存在的Plug 就必须重启core,也就是要退出Eclipse并重启。5 F) m- o; l; g3 n! Z
有很多人问Eclipse为什么要兼容OSGI规范而不是其他的规范呢?
/ b; j# o h! F! R7 V# h在 Eclipse被捐赠出来以前,Eclipse由OTI来开发,其目标是开发一个嵌入式Java软件的开发平台。互联网上现在仍然由很多的连接指向 Visual Age Micro Edition (VAME). 这也是SWT被构思的一个原因,他们想将SWT使用在嵌入式设备中的用户界面。这种渊源关系解释了当时为什么选择OSGI规范。% v/ A# D2 n7 r4 y( A' ^0 [( Y
另外一个原因是除了OSGI没有其他的规范。OSGI规范在轻量级服务架构应用方面被广泛的支持。而且OSGI被好多电信业的知名公司和一些其他行业的知名公司所支持。他们需要使用OSGI来同Sun的J2ME来抗衡。 |
|