`

Getting Started with OSGi_ Part3

阅读更多

      最近因为事情比较多,没想到OSGi这一系列文章一直没有机会翻译,心里有些后悔。好了,还是抓紧时间翻译第三部分——Bundles之间的相互依赖性。

 

      在我们上次的课程中,我们学习了如何启动和停止一个bundle,以及它们在框架内是如何相互交互的和它们的生命周期。但是bundle真正为了什么(这样翻译对吗)?

 

      每一个bundle是一个模块,它们允许我们将一个完整的项目切分成管理块,这样可以在OSGi运行的时候,加载进去。问题是无论我们是否喜欢,各个模块之间总是存在依赖性。在老式的jar文件中,从来没有一种可靠地方式指定依赖与其他jar包(类路径中的条目并不是可靠地表现方式)。然而你永远都不知道在运行的时候,jar中的代码是正常工作还是抛出异常。

 

      OSGi非常优雅的处理这个问题。而且,它表现的要比它说的更好。所以,让我们赶快去查看代码吧。遗憾的是我们到目前为止一直使用默认的包,但是这样的工作不会太久,现在我们使用恰当的包开始工作吧!让我们看一段非常简单的JavaBean,你需要将下面的代码拷贝到osgitut/movies文件夹下的Movie.java中

package osgitut.movies;

public class Movie {
	private final String title;
	private final String director;

	public Movie(String title, String director) {
		this.title = title;
		this.director = director;
	}

	public String getTitle() {
		return title;
	}

	public String getDirector() {
		return director;
	}
}

 

      现在,我们要在相同的package中创建一个接口,创建类文件MovieFinder.java,并且把下面的代码拷贝进去。

package osgitut.movies;
 
public interface MovieFinder {
    Movie[] findAll();
}
 

      接下来,让我们把这两个文件加入到我们的bundle中。是的,我们的bundle小的可笑,而且几乎一点用都没有。但是到目前为止,它很好。在此之前,我们需要创建一个manifest文件,因此创建并打开MoviesInterface.mf并且将下面的代码拷贝进去。

Manifest-Version: 1.0
Bundle-ManifestVersion: 2
Bundle-Name: Movies Interface
Bundle-SymbolicName: MoviesInterface
Bundle-Version: 1.0.0
Export-Package: osgitut.movies;version="1.0.0"

 

        这里有一行新的内容,我们以前没有看到过的:Export-Package。简单的说,这个包,osgitut.movies被从bundle中导出。但是,你以前是否想到过要将某个package中的代码只在你的jar包中可见呢?当然,你可以使用一些私有的类或者受保护的类去实现。但是他们对jar中的其他package同样是不可见的。因此OSGi有效的提供了新的代码保护层次:如果一个在你的bundle中,某些package没有加上Export-Package的标注,那么它仅仅在你的模块里可见。

 

      你可能注意到了在导出的package后面跟着一个版本号。在以后看来,这是很重要的。这里完全没有必要提供一个版本号,顺便说一下,如果你不自己动手的话,OSGi将自动的给你的package添加一个版本号“0.0.0”。我想实际运用中最好明确的添加一个版本号,便于以后识别。

 

      现在,让我们创建这个bundle:

> javac osgitut/movies/Movie.java osgitut/movies/MovieFinder.java
> jar -cfm MoviesInterface.jar MoviesInterface.mf osgitut/movies/*.class

 

      我们不要马上去安装这个bundle,也不要马上进行测试。我们还需要创建另外一个bundle,一个依赖于它的bundle。我们要创建一个具体的类去实现MovieFinder接口,因此,将下面的代码拷贝到osgitut/movies/impl/BasicMovieFinderImpl.java中。

package osgitut.movies.impl;

import osgitut.movies.*;

public class BasicMovieFinderImpl implements MovieFinder {
	private static final Movie[] MOVIES = new Movie[] {
			new Movie("The Godfather", "Francis Ford Coppola"),
			new Movie("Spirited Away", "Hayao Miyazaki") };

	public Movie[] findAll() {
		return MOVIES;
	}
}

 

       我们同样需要创建一个manifest文件,所以创建BasicMovieFinder.mf

Manifest-Version: 1.0
Bundle-ManifestVersion: 2
Bundle-Name: Basic Movie Finder
Bundle-SymbolicName: BasicMovieFinder
Bundle-Version: 1.0.0
Import-Package: osgitut.movies;version="[1.0.0,2.0.0)"

 

      注意到了吗?我们从哪个Export-package的bundle中将导出的package又导入了osgitut.movies包。同时,我们在Import-package中也添加了版本标记。框架在运行的时候使用这些标记去匹配导出的和导入的package。OSGi使用版本范围的方式区分了jar包中导出的部分和独有的部分,最有效的方式是我们动手指定版本号。

 

      再次声明:添加一个版本号,并不是十分必要的。它仅仅是一个比较好的习惯!

 

      现在,让我们根据下面的代码来编译并且建立今天的第二个bundle。

> javac -classpath MoviesInterface.jar osgitut/movies/impl/BasicMovieFinderImpl.java 
> jar -cfm BasicMovieFinder.jar BasicMovieFinder.mf osgitut/movies/impl/*.class

 

      最后,我们在Equinox中测试这些bundle。这次,我将给出完整的介绍。而且,我想你们已经准备好了。首先安装BasicMovieFinder的bundle,并且使用“ss”运行它,你将会发现这些bundle的状态如下:

id      State                Bundle
0       ACTIVE             org.eclipse.osgi_3.3.0.v20070208
4       INSTALLED       BasicMovieFinder_1.0.0

 

      (注意:或许你的bundle列表和我的有些不同,特别是bundle的ID,它取决于你最初安装其他bundle的次数,这些不用特别的在意。)

 

      “INSTALLED”这个状态框架已经获取了bundle,但是到目前为止,它仍被另一个bundle所决定。我们可以使用“refresh”命令来启动这个bundle。我们输入“refresh 4”来启动这个bundle并且用“ss”查看当前的bundle状态。

id      State                     Bundle
0       ACTIVE                  org.eclipse.osgi_3.3.0.v20070208
4       INSTALLED            BasicMovieFinder_1.0.0

 

       这个bundle仍然没有解析!当然,我们需要安装interface bundle。要确认这个问题的原因,我们可以使用“diag 4”获得调试信息。

file:BasicMovieFinder.jar [4]
  Missing imported package osgitut.movies_[1.0.0,2.0.0).

 

       是的,问题就是这样的:我们无法导入这个osgitut.movies的package,是因为当前没有bundle导出它。因此,现在安装bundle——MovieInterface.jar,并且使用“ss”命令查看结果:

id      State              Bundle
0       ACTIVE           org.eclipse.osgi_3.3.0.v20070208
4       INSTALLED     BasicMovieFinder_1.0.0
5       INSTALLED     MoviesInterface_1.0.0

 

       最后的步骤是通过使用“refresh 4”来解析Bundle——BasicMovieFinder。然后输入“ss”查看状态:

id      State             Bundle
0       ACTIVE          org.eclipse.osgi_3.3.0.v20070208
4       RESOLVED     BasicMovieFinder_1.0.0
5       RESOLVED     MoviesInterface_1.0.0

 

        BasicMovieFider终于处于“RESOLVED”状态了。这是必须的一步,因为只有处于“RESOLVED”状态了,才可以被“start”。而且不再取决于其他的Bundle。

 

        注意,通常我们没有必要这样做。Bundle会根据它们的需要自动的被“RESOLVE”。因此,即使我们没有使用“refresh”,它也会自动的处于“RESOLVED”状态。

 

        这就是本节课的内容,OSGi还有更多有趣的东西等着我们,来看看Chris Aniszczyk's excellent article on IBM developerWorks 的内容。敬请期待下期课程,我们在那里开始深入学习OSGi服务。

分享到:
评论

相关推荐

    Getting Started with OSGi_ Part1

    在标题“Getting Started with OSGi Part1”中,指明了这是一个关于OSGi入门的系列文章中的第一部分。描述部分虽然为“NULL”,但可以从给定的内容中提取出文章的重点信息。标签“源码工具”可能意味着在文章的系列...

    Getting Started with OSGi_ Part2

    3. bundle的持久性:OSGi框架能够保存其状态,这包括当前已安装的bundle。这使得OSGi能够在应用重启后仍然保持其之前的配置,从而实现状态的持久化。 通过这些内容,读者可以了解到如何使用OSGi API来实现模块化和...

    OSGI.rar_OSGI eclipse_eclipse osgi_java OSGI_osgi

    3. **Eclipse与OSGI**:Eclipse是如何基于OSGI构建的,每个插件如何作为OSGI Bundle运行,以及如何通过Eclipse插件系统利用OSGI的灵活性。 4. **模块化开发**:如何将应用程序分解为可独立升级的模块,降低耦合度,...

    org.eclipse.osgi_3.7.0.v20110613及源码

    《深入理解OSGi:以org.eclipse.osgi_3.7.0.v20110613及其源码为例》 OSGi(Open Services Gateway Initiative)是一种Java模块化系统,它为开发人员提供了动态模块化的解决方案,使得Java应用程序能够更好地管理和...

    Oscar.rar_java OSGI_oscar_osgi_osgi oscar

    3. **服务注册和查找**:OSGI服务是组件间通信的关键,通过服务注册表,组件可以提供服务或者查找并消费其他组件提供的服务,实现了松耦合。 4. **依赖管理**:OSGI允许bundle声明它们的依赖,系统会自动处理这些...

    OSGi.NET-master.zip_c#osgi_osgi_osgi.net github_模块化

    "OSGi.NET-master.zip_c#osgi_osgi_osgi.net github_模块化" 这个标题揭示了几个关键信息。首先,它提到了“OSGi.NET”,这是一个专门为.NET平台实现的OSGi(Open Service Gateway Initiative)框架。OSGi是一个Java...

    OSGi_with_Eclipse_Equinox_-_Tutorial

    ### OSGi与Eclipse Equinox教程 #### 1. OSGi概述 **1.1 概览** OSGi是一种在Java运行时环境中的服务和模块化平台规范。该规范由多个部分组成,其中核心部分定义了一种组件和服务模型。这种模型允许动态激活、去...

    tomcat-osgi.rar_OsgiContentFactory_osgi_osgi tomcat 集成_osgi tom

    标题中的“tomcat-osgi.rar_OsgiContentFactory_osgi_osgi tomcat 集成_osgi tom”表明这是一个关于Tomcat服务器与OSGi框架集成的资源包,其中可能包含了如何在Tomcat中使用OsgiContentFactory来管理OSGi服务的内容...

    OSGi原理与最佳实践(完整版)&OSGi_in_action

    3. **生命周期管理**:描述OSGi bundle的生命周期,包括启动、暂停、恢复和停止等状态,以及如何控制这些状态。 4. **依赖管理**:讨论如何在OSGi环境中管理依赖关系,包括导入导出包、解析依赖和处理版本冲突。 5...

    osgi_spring_dm_jr

    3. Java Runtime Environment在OSGi中的特殊性,如何支持每个bundle的独立运行环境。 4. 如何阅读和理解`osgi_platform`文件,可能涉及的配置、服务和API的使用。 5. OSGi与Spring集成的优势,如增强应用程序的可...

    it_ismb_pert_osgi_dal_web-apis-源码.rar

    《IT_ismb_pert_osgi_dal_web-apis源码解析》 在现代软件开发中,模块化已经成为提升代码可维护性和复用性的重要手段。OSGi(Open Service Gateway Initiative)作为Java平台上的模块化系统,为构建可扩展、动态的...

    org.eclipse.osgi_3.8.1.dist.jar

    在ubuntu软件中心安装的eclipse启动存在异常,需要在plugins中加入这个文件才能正常启动

    OSGi_R4_Spec_zh_cn_origional

    3. **生命周期管理**:OSGi框架提供了对bundle的完整生命周期管理,包括安装、启动、停止、更新和卸载等操作。这使得开发者可以在运行时动态地添加、修改或移除功能。 4. **包依赖解析**:OSGi框架负责解析和管理...

    org.eclipse.osgi_3.9.0

    org.eclipse.osgi_3.9.0.v20130529-1710.jar下载

    OSGi Technology 教程

    "Getting Started with OSGi 3 Dependencies between Bundles.doc"深入探讨了捆绑包间的依赖关系。在OSGi中,依赖管理是关键,因为它允许模块化系统中的组件动态地发现和使用彼此的服务。文档会解释如何声明和解决...

    OSGI.zip_osgi_osgi原理

    OSGI(Open Services Gateway Initiative)是一种开放的标准框架,主要用于创建模块化、动态的Java应用程序。它的核心理念是将Java应用程序分解为独立的、可热插拔的组件,这些组件被称为服务单元(Bundles)。OSGI...

    osgi.rar_gateway_open_open init_osgi_osgi code.r

    OSGi(Open Service Gateway Initiative)指OSGi Alliance组织制定的一个基于Java语言的服务(业务)规范——OSGi服务平台(Service Platform)。 它被广泛应用于嵌入式系统中,大名鼎鼎的eclipse也是基于此框架的,...

    OSGI.rar_osgi_practice

    3. **依赖管理**:OSGI框架自动处理模块之间的依赖关系,每个Bundle可以声明其依赖的服务和其他Bundle,确保正确加载和解析。 4. **服务注册与发现**:OSGI服务注册表允许模块发布和查找服务。通过服务接口,模块...

Global site tag (gtag.js) - Google Analytics