zoukankan      html  css  js  c++  java
  • 使用NetBeans6开发OSGi应用(3)——整合Knopflerfish![88250原创]

    转载请保留作者信息:

    作者:88250

    Bloghttp:/blog.csdn.net/DL88250

    MSN & Gmail & QQDL88250@gmail.com


    摘要

    上一次,我们编写了两个Bundles,一个是服务提供商,一个是使用服务的客户 ,运行得还不错 :-)
    这一次,我们先简要分析一下KF(Knopflerfish)框架的设计,学习应用程序框架的设计。最后,结合上一次文章结尾时提到了关于控制KF框架、让OSGi服务于我们的应用的问题,今天就围绕这些内容展开。

    关于Knopflerfish框架的设计

    在开始,我们将看一下KF框架的设计。

    Main

    在阅读了KF框架的一些代码后,从KF框架的主程序入手(org.knopflerfish.framework.Main)我们可以看出,KF除了实现OSGi规范,实现了自己的framework(org.knopflerfish.framework.Framework)外,主要是围绕它的框架启动类:org.knopflerfish.framework.Main做了一系列的铺垫:比如所实现的OSGi规范的版本(我的版本是OSGi 4.0.6版本),存储Bundle的文件位置,操作系统版本,等等。
    这个Main类,主要做的是命令行参数(启动参数)的处理,因为KF框架启动的时候可以用xargs文件(把所有参数写成一个文件),所以处理上比较繁琐。在Main下面的handleArgs方法可以看出,所有的Bundles的基本操作(start、stop、install、etc.)都是调用org.knopflerfish.framework.Framework这个类实现的,这个类就是KF框架的基本实现,已经把功能封装地相当好用了!

    那我们应该直接使用Framework类吗?

    我们应该直接使用KF实现的Framework类,但是整个框架的启动铺垫是很繁琐的。从Main还有其相关的Utils的代码量就可以看出。在整个框架启动之前,要做一系列的铺垫。
    这里,结合我自己的项目,由于时间比较紧了,再重写这些可能时间不允许,所以我选择的是改写Main,把那个Main类作为自己应用框架的一个对KF的基本封装。具体做法就是委托Framework类的一些方法,暴露这些方法在Main外部。

    总之,要基于Knopflerfish,完成自己的一个应用框架还是比较简单的 :-)

    让我们简单实践一下!

    准备

    上一次 :-)

    开工:

    1. 创建工程

    打开NB6,创建一个普通Java应用工程——MyOSGiFramework:



    注意那个version文件,这个文件是指KF实现的OSGi的版本,在OSGi框架实现里,有一个Version类,用于版本的管理。要在我们的src目下建立一个version文件。

    2.改写Knopflerfish的Main类

    添加对Bundle的基本操作到Main类里,达到封装KF框架的目的。下面是添加的一些示例方法:
    /**
         * Get the bundle context used by the system bundle.
         * 
    @return system <code>BundleContext</code>
         
    */
        
    public static BundleContext getBundleContext() {
            
    return framework.getSystemBundleContext();
        }

        
    /**
         * Start a bundle.
         * 
    @param id Id of bundle to start
         
    */
        
    public static void startBundle(long id) {
            
    try {
                framework.startBundle(id);
            } 
    catch (BundleException ex) {
                Logger.getLogger(Main.
    class.getName()).log(Level.SEVERE, null, ex);
            }
        }

        
    /**
         * Stop a bundle.
         * 
    @param id Id of bundle to stop
         
    */
        
    public static void stopBundle(long id) {
            
    try {
                framework.stopBundle(id);
            } 
    catch (BundleException ex) {
                Logger.getLogger(Main.
    class.getName()).log(Level.SEVERE, null, ex);
            }
        }

    这里,做的工作就是“纯”委托。

    编写我们对Main的测试类:
    /*
     * @(#)MainTest.java
     * 
     * This program is free software; you can redistribute it and/or modify
     * it under the terms of the GNU General Public License as published by
     * the Free Software Foundation; either version 3 of the License, or
     * (at your option) any later version.
     * 
     * This program is distributed in the hope that it will be useful,
     * but WITHOUT ANY WARRANTY; without even the implied warranty of
     * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
     * GNU Library General Public License for more details.
     * 
     * You should have received a copy of the GNU General Public License
     * along with this program; if not, write to the Free Software
     * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
     
    */
    package myosgiframework;

    import org.knopflerfish.framework.Main;
    import org.osgi.framework.Bundle;
    import org.osgi.framework.BundleContext;

    /**
     * A test case of <code>org.knopflerfish.framework.Main</code>.
     * <p>
     * Base on knopflerfish framework, modify some source in <code>Main</code>,
     * annotate these modifications with <code>
    @since</code> mark, 
     * mark as <tt>
    @since 4.0.6</tt>.
     * </p>
     * 
    @author 88250
     * 
    @version 1.0.0.0, Feb 15, 2008
     
    */
    public class MainTest {

        
    /**
         * Program entry point.
         * 
    @param args should be <code>null</code>
         
    */
        
    public static void main(String[] args) {
            Main.main(args);
            Main.startBundle(
    1);
            displayBundlesStatus();
            Main.stopBundle(
    1);
            displayBundlesStatus();
            Main.shutdown(
    0);
        }

        
    private static void displayBundlesStatus() {
            BundleContext bc 
    = Main.getBundleContext();

            Bundle[] b 
    = bc.getBundles();
            
    for (int i = 0; i < b.length;
                    i
    ++) {
                Bundle bundle 
    = b[i];
                System.out.println(
    "ID: #" + bundle.getBundleId() +
                                   
    "        Location: " + bundle.getLocation() +
                                   
    "        Status: " + bundle.getState());
            }
        }
    }

    3. 测试

    还记得上一次我们的那个Bundle吗?
    为了它启动在我们的框架里,编写一个启动参数文件secondosgi.xargs:
    -istart /home/daniel/Work/Sources/Java/SecondOSGi/dist/SecondOSGi.jar

    然后,修改启动参数:

    测试输出:



    总结

    这一次,我们简单地分析了KF框架的启动,还有一些设计。并修改了KF框架的启动类,作为了我们自己的一个底层应用框架封装。下一次,我们将结合具体的一个项目(把OSGi作为整个项目的实现基础,支持插件的辞典——StoneAgeDict)实践OSGi!
  • 相关阅读:
    记录一些css奇淫技巧
    git的一些常用基础命令
    # 实现二维表格行头和列头固定的解决方案
    拿来-util工具函数
    mpvue开发小程序项目遇到的问题
    mac设置终端命令行别名alias(git、npm)
    简单配置nginx反向代理,实现跨域请求
    以前的阅读计划搁浅了,这里是分割线
    源码阅读心得11-13
    源码阅读心得1-10
  • 原文地址:https://www.cnblogs.com/lanzhi/p/6470595.html
Copyright © 2011-2022 走看看