`
erylee
  • 浏览: 109674 次
社区版块
存档分类
最新评论

OpenCore:基于OSGi开发纯插件体系结构的WEB应用程序

    博客分类:
  • OSGi
阅读更多
随着OSGi/Equinox逐渐成为Java EE服务端的基础软件架构,OSGi上部署WEB应用程序的解决方案日渐成熟。这里介绍三种目前我们所知的解决方案,前两种是Equinox组织提出的方案,后一种是OpenCore平台采取的解决方案。

解决方案一: 部署OSGi/Equinox在Servlet容器中

具体实现: 把OSGi/equinox打包在WAR中,当Servlet容器加载WAR时,启动OSGi框架。
WEB-INF的目录结构大致如下(大致如此):
  1. * /WEB-INF  
  2.       o /web.xml (with one servlet entry assigning all incoming requests to the BridgeServlet)  
  3.       o /lib/servletbridge.jar (the classes associated with the equinox.servletbridge)  
  4.       o /eclipse (the eclipse platform directory)  
  5.             + launch.ini (contains framework properties that will allow override of any eclipse specific System Properties)  
  6.             + /configuration (contains config.ini which lists the bundles you want to have available)  
  7.             + /features  
  8.             + /plugins  

部署结构如下图(转载):




个人感觉这个解决方案使用价值不大。

解决方案二: Web服务器与Servlet容器嵌入在OSGi/Equinox

具体实现: 把Jetty当作一个插件嵌入到OSGi/Equinox中,并基于Jetty实现OSGi标准中的HTTP服务,其他插件可以通过该服务注册Servlet和静态页面。

OSGi标准中的HTTP服务接口如下:

 
  1. package org.osgi.service.http;  
  2.   
  3. import javax.servlet.Servlet;  
  4. import javax.servlet.ServletException;  
  5. import java.util.Dictionary;  
  6.   
  7. public interface HttpService {  
  8.     public void registerServlet(String alias, Servlet servlet,  
  9.             Dictionary initparams, HttpContext context)  
  10.             throws ServletException, NamespaceException;  
  11.   
  12.     public void registerResources(String alias, String name,  
  13.             HttpContext context) throws NamespaceException;  
  14.   
  15.     public void unregister(String alias);  
  16.   
  17.     public HttpContext createDefaultHttpContext();  
  18. }  


部署结构图(转载):



因为OSGi是最早为嵌入式系统设计,所以OSGi标准中的HTTP服务只提供了有限的Servlet与静态资源的发布功能,没有一个完整的WEB容器概念,这种模式更适合通过WEB方式暴露(Export)服务,不太适合开发展现层的WEB应用。

通过Equinox提供的扩展/扩展点功能可以简化这种方式WEB应用的开发,就是通过plugin.xml来配置Servlet和静态页面的注册。

解决方案三: 设计适合OSGi环境的Servlet容器,构建纯插件体系结构的WEB层

具体实现:"插件"与我们通常所说软件"模块"的一个区别是:插件能自我描述,加载运行在插件容器中。那么,我们可以分层扩展一个插件的自我描述,用类似Decorator的模式为插件增加“特征”描述。 所以,我们在OpenCore中定义了三种特征的插件,如下图:



这三种插件类型间关系类似Decorator模式,从内到外增加"特征"描述:
  1. OSGi标准插件,自描述文件"META-INF/MANIFEST.MF"
  2. OpenCore插件,增加自描述文件"META-INF/opencore.xml",实现符合OSGi环境的依赖注册(IoC)与动态扩展点
  3. OpenCore Web插件,增加自描述文件"WEB-INF/web.xml"(符合Servlet规范),WEB特性的插件,可以部署在Servlet容器内

这样我们可以把一个应用的WEB层像业务层一样,分割为多个插件,部署在OSGi/Equinox的框架中.

部署结构图:






我 们觉得这种方式以合适的力度将WEB层分割为插件部署在OSGi框架上,充分的发挥了OSGi体系结构的强大之处,也提高了WEB层开发部署的灵活性。目 前,业界好像也有很多项目是采用这中方式部署。这种部署方式的缺点是,不得不修改Jetty容器的实现,以使其适应OSGi的环境,我们希望Jetty以 后能支持这个功能:)

Google Code上发布了一个基于OpenCore的示例项目linktalk,一个基于GWT、Equinox、OpenCore的Ajax聊天室。

项目地址: http://code.google.com/p/lintkalk

源码下载: svn checkout https://linktalk.googlecode.com/svn/trunk/project

程序下载: svn checkout https://linktalk.googlecode.com/svn/trunk/release

相关资源:

http://www.eclipse.org/equinox/server/http_quickstart.php
分享到:
评论
5 楼 neusoft_jerry 2012-03-07  
学习啦!
4 楼 shaucle 2007-01-29  
楼上的真幸福。。。
3 楼 chinakite 2007-01-29  
前两天还在跟女友讨论这个问题, 得出的结论是, OSGi至少要在OS之上, 应用服务器之下的, 也就是第二种方案; 当然, 第三种方案是最好的, 但是目前还看不到实现.

目前想的还不够透彻, 有机会与楼主多交流, 
2 楼 shaucle 2007-01-29  
学习一下
1 楼 vaja 2007-01-29  
项目地址应该是
http://code.google.com/p/linktalk/

相关推荐

    eclipse插件开发

    1. **Eclipse插件体系结构**: Eclipse采用插件化架构,每个功能模块都是一个独立的插件,这些插件通过OSGi(Open Service Gateway Initiative)框架进行交互。OSGi确保了插件之间的动态加载和依赖管理。 2. **...

    java开源包11

    SpeechLion 是一个语音识别程序,主要用来处理桌面命令,基于 Sphinx-4 语音识别引擎开发。用户可以通过该软件来控制 Linux 桌面,例如打开google搜索、鼠标点击、下一窗口、打开帮助、静音等操作。 Java发送短信包...

    java开源包1

    SpeechLion 是一个语音识别程序,主要用来处理桌面命令,基于 Sphinx-4 语音识别引擎开发。用户可以通过该软件来控制 Linux 桌面,例如打开google搜索、鼠标点击、下一窗口、打开帮助、静音等操作。 Java发送短信包...

    java开源包2

    SpeechLion 是一个语音识别程序,主要用来处理桌面命令,基于 Sphinx-4 语音识别引擎开发。用户可以通过该软件来控制 Linux 桌面,例如打开google搜索、鼠标点击、下一窗口、打开帮助、静音等操作。 Java发送短信包...

    java开源包3

    SpeechLion 是一个语音识别程序,主要用来处理桌面命令,基于 Sphinx-4 语音识别引擎开发。用户可以通过该软件来控制 Linux 桌面,例如打开google搜索、鼠标点击、下一窗口、打开帮助、静音等操作。 Java发送短信包...

    java开源包6

    SpeechLion 是一个语音识别程序,主要用来处理桌面命令,基于 Sphinx-4 语音识别引擎开发。用户可以通过该软件来控制 Linux 桌面,例如打开google搜索、鼠标点击、下一窗口、打开帮助、静音等操作。 Java发送短信包...

    java开源包5

    SpeechLion 是一个语音识别程序,主要用来处理桌面命令,基于 Sphinx-4 语音识别引擎开发。用户可以通过该软件来控制 Linux 桌面,例如打开google搜索、鼠标点击、下一窗口、打开帮助、静音等操作。 Java发送短信包...

    java开源包10

    SpeechLion 是一个语音识别程序,主要用来处理桌面命令,基于 Sphinx-4 语音识别引擎开发。用户可以通过该软件来控制 Linux 桌面,例如打开google搜索、鼠标点击、下一窗口、打开帮助、静音等操作。 Java发送短信包...

    java开源包4

    SpeechLion 是一个语音识别程序,主要用来处理桌面命令,基于 Sphinx-4 语音识别引擎开发。用户可以通过该软件来控制 Linux 桌面,例如打开google搜索、鼠标点击、下一窗口、打开帮助、静音等操作。 Java发送短信包...

    java开源包8

    SpeechLion 是一个语音识别程序,主要用来处理桌面命令,基于 Sphinx-4 语音识别引擎开发。用户可以通过该软件来控制 Linux 桌面,例如打开google搜索、鼠标点击、下一窗口、打开帮助、静音等操作。 Java发送短信包...

    java开源包7

    SpeechLion 是一个语音识别程序,主要用来处理桌面命令,基于 Sphinx-4 语音识别引擎开发。用户可以通过该软件来控制 Linux 桌面,例如打开google搜索、鼠标点击、下一窗口、打开帮助、静音等操作。 Java发送短信包...

    java开源包9

    SpeechLion 是一个语音识别程序,主要用来处理桌面命令,基于 Sphinx-4 语音识别引擎开发。用户可以通过该软件来控制 Linux 桌面,例如打开google搜索、鼠标点击、下一窗口、打开帮助、静音等操作。 Java发送短信包...

    java开源包101

    SpeechLion 是一个语音识别程序,主要用来处理桌面命令,基于 Sphinx-4 语音识别引擎开发。用户可以通过该软件来控制 Linux 桌面,例如打开google搜索、鼠标点击、下一窗口、打开帮助、静音等操作。 Java发送短信包...

    Java资源包01

    SpeechLion 是一个语音识别程序,主要用来处理桌面命令,基于 Sphinx-4 语音识别引擎开发。用户可以通过该软件来控制 Linux 桌面,例如打开google搜索、鼠标点击、下一窗口、打开帮助、静音等操作。 Java发送短信包...

Global site tag (gtag.js) - Google Analytics