 鲜花( 0)  鸡蛋( 0)
|
OSGi是Open Service Gateway Initiative的简称,该组织建立于1999年,是一个非赢利机构,旨在建立一个开放的服务规范,为通过网络向设备提供服务建立开放的标准。
& z$ j1 }' m& x0 R" k2 }& ^8 eOSGI 规范包括了构建开放的可交付网络服务的各方面,OSGI规范又包括了以下子规范。
" x2 c9 S9 e1 ^1 OFramework规范(OSGI核心,提供一个安全的可管理的Java Framework来部署可扩展的Java服务。) . [1 p) n- t! `8 B
Package Admin Service规范(来管理不同的Bundle之间的引用关系。当Bundle更新或者反安装时判断是否有其他的服务正在使用当前的Bundle)+ b9 f+ Z+ V3 p7 ]! W
Start Level规范(定义了启动和停止一个OSGi Service Platform时,不同的Bundles的启动或者停止的先后顺序)
' }: }1 l! S3 f" ^3 p- Z$ }4 G: ]: p9 DPermission Admin Service规范(Bundle是否许可执行另外的Bundle的代码)
% w) O% @: g0 f3 LURL Handlers Service规范(怎样注册URL Schema,如何将java.io.InputStream对象转换为特定的Java对象)7 y. m% A- M# r& `0 E9 D
Log Service规范 (以下略。。。)7 r x" {6 n" X1 {% c
Configuration Admin Service规范
9 F6 J" H4 e7 D( C! A' U" zDevice Access Specification. W9 J+ C; t) }
User Admin Service Specification
- U8 c5 z! ]" e) T0 f m4 c5 BIO Connector Service Specification
; j7 O! |4 _9 v5 T& uHttp Service Specification
. B; e3 W/ _% ~Preference Service Specification& C9 b4 H9 b) Y8 t/ B2 O
Wire Admin Service Specification8 G2 p# f; |- x P- h
XML Parser Service Specification# R! _& ~3 P" O' N3 g
Metatype Specification
; G& J6 v( c7 VService Tracker Specification2 k4 T% p& @* u+ b p% E
Measurment and State Specification
+ J/ W P4 Z( e& O4 P" r' H1 @Position Specification
. p. u0 X1 x6 x2 S2 G- NExecution Environment Specfication
+ s2 y9 w0 b& R( c6 z+ m, UOSGI Framework0 ?# y# }7 \6 W
Framework是OSGI Service Platform规范的核心组成部分。它提供了一个通用的、安全可管理的Java framework。通过这个Framework可以支持一种叫做bundles的Service application的部署和扩展。; A8 N' u/ W7 c4 U( E# s+ q) z+ T4 K
OSGI兼容设备可以下载并且安装OSGI bundles,也可一当他们不再需要的时候删除。bundles安装后会注册一定数量的Services,并被由同一个Framework下的其他bundles使用。3 w/ t! z0 U. }4 Q2 g) v
在一个动态扩展的的 OSGI环境中,Framework管理bundles的安装和更新。同时也管理bundles和Services之间的依赖关系。: i% y) b. i9 a# ]( q$ t6 L
Framework提供给bundle开发者必须的资源来在Java平台上开发,为开发的bundles提供了代码动态加载的功能, 也使得开发者开发、部署一个大规模的Services变的很容易。
# x! L$ h0 ]+ C其 次,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.
1 L5 g2 O! M1 K/ z0 G0 ]6 n一个一致的编程模型帮助开发者可以应付一些可估计的危急错误。Framework将会运行在不同的硬件环境上,但一致的接口确保软件组建可以运行在一致的服务接口上。+ I1 z C; |2 c& P
The Bundle Object
+ s: D# a* K9 `对于每一个安装在OSGI Service Platform的bundle都有一个与之关联的bundle object。一个bundle对象用来管理bundle的生命周期。这项工作通常由Management Agent来做。1 `4 c/ L& J/ q7 S# m6 w9 D! a
Bundle State0 H2 R' s; D& K: K; h+ c+ d5 m
bundle有以下状态;
% M- n. i& M( }0 M5 \( Y/ ?# aINSTALLED – The bundle has been successfully installed. Native code clauses must have been validated.8 m5 N5 h8 t& |3 i# Y
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.) i+ v# G8 h3 M F t4 q( m
STARTING – The bundle is being started, and the BundleActivato r. start method has been called and has not yet returned.
3 @8 C% L# ^9 b( aSTOPPING – The bundle is being stopped, and the BundleActivato r. stop method has been called and has not yet returned.5 C# \" I2 L' }4 U( V# j# t A
ACTIVE – The bundle has successfully started and is running.2 r9 n/ T: @& J4 n
UNINSTALLED – The bundle has been uninstalled. It cannot move into another state.
' w1 [3 g ?0 d; k6 Heclipse 3.0并没有用OSGI替换掉原来的PlugIn机制。它只是做了与标准兼容的工作:给用户提供了一系列的API来访问,在这个过程中,就必须要做一些改 变(比如plugin registry和loading机制)来同OSGI标准完全兼容。最初的Plugin核心只支持静态的扩展,就是说,如果要改变一个已经存在的Plug 就必须重启core,也就是要退出Eclipse并重启。+ i. q3 B0 c' W. t
有很多人问Eclipse为什么要兼容OSGI规范而不是其他的规范呢?
v- K# D! O# a8 L在 Eclipse被捐赠出来以前,Eclipse由OTI来开发,其目标是开发一个嵌入式Java软件的开发平台。互联网上现在仍然由很多的连接指向 Visual Age Micro Edition (VAME). 这也是SWT被构思的一个原因,他们想将SWT使用在嵌入式设备中的用户界面。这种渊源关系解释了当时为什么选择OSGI规范。
+ I, ?: d" J) o' e3 j另外一个原因是除了OSGI没有其他的规范。OSGI规范在轻量级服务架构应用方面被广泛的支持。而且OSGI被好多电信业的知名公司和一些其他行业的知名公司所支持。他们需要使用OSGI来同Sun的J2ME来抗衡。 |
|