`

Apache ServiceMix 初探

 
阅读更多

转自:http://blog.csdn.net/lubiaopan/article/details/16339007

该文章算是笔记,针对的是apache-servicemix-4.5.3相配套的qucikstart.pdf文档。

基本操作

启动servicemix:运行 "apache-servicemix-4.5.3\bin"文件夹下面的servicemix.bat,弹出ServiceMix的控制台,在这个控制台上可以增加或删除bundles,安装各种可选的特性。

查看已经安装的bundles:运行 osgi:list  命令

查看日志:运行 log:display 命令

只查看异常日志:运行 log:display-exception 命令

设置日志级别:运行 log:set DEBUG 命令(以DEBUG举例)

查看某个级别的日志:运行 log:display | grep DEBUG(以DEBUG举例)

查看可用的功能组件:运行 feature:list 命令

查看某个类别的可用功能组件:运行 feature:list | grep camel (以camel举例)

安装某个功能组件:运行 feature:install webconsole (以webconsole举例)

    webconsole是网页版的管理客户端,URL为:http://localhost:8181/system/console ,用户名/密码:smx/smx

    

简单示例:使用Camel

Apache Camel是一个开源的、功能丰富的应用集成框架,它支持常见的EIP模式,是一个强大的基于规则的路由引擎,可以轻松的实现消息路由和消息转换,ServiceMix对Camel进行了深度集成来支持各种复杂的ESB功能。

本例中实现一个非常简单的路由功能:将文件从 camel/input 文件夹移到 camel/output 文件夹。

1、创建路由配置文件study_one.xml (camel支持两种风格的路由配置文件,一种是针对blueprint容器的,一种是针对spring容器的,这里用的是blueprint)

[html] view plaincopy
 
  1. <?xml version="1.0" encoding="UTF-8"?>  
  2. <blueprint xmlns="http://www.osgi.org/xmlns/blueprint/v1.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"  
  3.       xsi:schemaLocation="  
  4.       http://www.osgi.org/xmlns/blueprint/v1.0.0  
  5.       http://www.osgi.org/xmlns/blueprint/v1.0.0/blueprint.xsd">  
  6.   <camelContext xmlns="http://camel.apache.org/schema/blueprint">  
  7.     <route>  
  8.       <!--camel采用URI来描述各种组件,如file:表示文件,http:表示web,activemq:表示消息队列-->  
  9.       <from uri="file:camel/input"/><!--文件路由的起始文件夹-->  
  10.       <log message="Moving ${file:name} to the output directory"/><!--文件路由时需打印的日志内容-->  
  11.       <to uri="file:camel/output"/><!--文件路由的终点文件夹-->  
  12.     </route>  
  13.   </camelContext>  
  14. </blueprint>  

2、发布和启动路由

第一步:将study_one.xml移到ServiceMix下的deploy文件夹下,该文件将会被ServiceMix加载和发布。

第二步:转到ServiceMix根目录,会发现新创建了一个camel/input 文件夹。

第三步:向camle/input文件夹下copy任一文件,然后到camel/output下查看,会发现copy的同时文件被传递到了ouput下面,说明路由生效了。

第四步:查看日志,运行log:display命令,将会发现被路由文件的相关信息。

3、管理路由

第一步:查找study_one.xml路由文件对应的bundle。运行osgi:list,从运行结果中查找study_one.xml,截图如下:

从截图中可知该路由对应的bundle id是181,Blueprint Container被创建出来用于启动这个路由(如果用的是spring配置文件,则Spring那一些会显示Started)。

第二步:终止路由。运行osgi:stop 181,将路由终止,向camel/input下copy一个文件,然后到camel/output下查看,文件未被移过来,说明终止成功。

第三步:开启路由。运行osgi:start 181,去camel/output下查看,第二步未被移动的文件被移到了该文件夹下,说明启动成功。

使用ActiveMQ

1、创建第一个路由,该路由将activemq/input文件夹下的文件路由到atvive/output文件夹下,创建的原理及步骤同上。

其中配置文件study_MQ1.xml的内容如下:

[html] view plaincopy
 
  1. <?xml version="1.0" encoding="utf-8"?>  
  2. <blueprint  
  3.   xmlns="http://www.osgi.org/xmlns/blueprint/v1.0.0"  
  4.   xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"  
  5.   xsi:schemaLocation="  
  6.   http://www.osgi.org/xmlns/blueprint/v1.0.0  
  7.   http://www.osgi.org/xmlns/blueprint/v1.0.0/blueprint.xsd">  
  8.   <camelContext xmlns="http://camel.apache.org/schema/blueprint">  
  9.     <route>  
  10.       <from uri="file:activemq/input"/>  
  11.       <to uri="file:activemq/output"/>  
  12.       <setBody>  
  13.         <simple>  
  14.           FileMovedEvent(file: ${file:name}, timestamp: ${date:now:hh:MM:ss.SSS})  
  15.         </simple>  
  16.       </setBody>  
  17.       <to uri="activemq://events" />  
  18.     </route>  
  19.   </camelContext>  
  20. </blueprint>  

该文件和上面study_one.xml最大的区别在于,该文件对应的路由不再直接记录move日志,而是将待记录的日志内容以消息的方式发送到MQ中。
2、创建第二个路由,该路由负责从MQ中去数据,然后将数据move到日志中去。

其中配置文件study_MQ2.xml的内容如下:

[html] view plaincopy
 
  1. <?xml version="1.0" encoding="utf-8"?>  
  2. <blueprint  
  3.   xmlns="http://www.osgi.org/xmlns/blueprint/v1.0.0"  
  4.   xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"  
  5.   xsi:schemaLocation="  
  6.   http://www.osgi.org/xmlns/blueprint/v1.0.0  
  7.   http://www.osgi.org/xmlns/blueprint/v1.0.0/blueprint.xsd">  
  8.   <camelContext xmlns="http://camel.apache.org/schema/blueprint">  
  9.     <route>  
  10.       <from uri="activemq://events"/>  
  11.       <to uri="log:events"/>  
  12.     </route>  
  13.   </camelContext>  
  14. </blueprint>  

发布好这个路由文件之后,通过log:display命令就可以查看activemq/input对应的日志信息了。

MQ最大的特点就是发送数据一方和取数据的一方是完全透明,两者之间不需要建立连接。当study_MQ2.xml的路由关闭的时候如果向activemq/input中copy文件,日志信息照样会传到MQ中,当MQ2启动的时候它照样会取到这些信息。

分享到:
评论

相关推荐

    Apache ServiceMix Specs :: JAXP API 1.3

    Apache ServiceMix Specs :: JAXP API 1.3

    org.apache.servicemix.bundles.elasticsearch-1.0.1_1.zip

    标题中的"org.apache.servicemix.bundles.elasticsearch-1.0.1_1.zip"表明这是一个与Apache ServiceMix相关的软件包,特别地,它包含了Elasticsearch的一个特定版本(1.0.1)的bundle。Apache ServiceMix是基于Java...

    apache-servicemix-4.4-fuseesb第五部分

    Apache ServiceMix 和 Fuse ESB 是两个紧密相关的开源企业服务总线(ESB)项目,它们在集成和管理企业应用程序方面发挥着关键作用。本部分主要关注 Apache ServiceMix 的第四个主要版本,即 4.4 版本,以及与之关联...

    apacheservicemix4.4fuseesb-part2

    Apache ServiceMix 4.4 和 Fuse ESB 是企业服务总线(Enterprise Service Bus,ESB)的开源实现,它们在IT行业中扮演着重要的角色。Apache ServiceMix 是一个基于 Java 应用服务器,它实现了多种服务导向架构...

    org.apache.servicemix.bundles.spring-jdbc-3.2.8.RELEASE_2.zip

    标题 "org.apache.servicemix.bundles.spring-jdbc-3.2.8.RELEASE_2.zip" 提供的信息表明,这个压缩包包含了 Apache ServiceMix 的一个捆绑包,具体是 Spring JDBC 模块的 3.2.8.RELEASE 版本的第二次更新。Apache ...

    servicemix

    知识点:Apache ServiceMix及其在企业集成中的应用 一、Apache ServiceMix简介 Apache ServiceMix是基于Java Business Integration(JBI)规范的企业服务总线(ESB)实现,它提供了构建和部署服务组合的强大平台,...

    servicemix:Apache ServiceMix

    Apache ServiceMix 是一个开源的企业级服务总线(ESB)和集成平台,它基于Java语言并采用OSGi(Open Services Gateway Initiative)框架构建。ServiceMix是Apache软件基金会的一部分,致力于提供一个灵活、可扩展的...

    servicemix-bundles:Apache ServiceMix捆绑包的镜像

    Apache ServiceMix是一个开源的企业服务总线(ESB)和应用服务器,它基于OSGi(开放服务网关规范)框架,提供了集成不同系统和服务的能力。这个项目的主要目标是提供一个灵活、可扩展且易于管理的平台,用于实现企业...

    servicemix5:Apache ServiceMix 5的镜像

    Apache ServiceMix 5 是一个基于 OSGi 的企业级服务集成平台,它允许开发者通过统一的框架整合不同的Java EE、Web服务、SOA组件以及多种轻量级技术。这个镜像可能包含了Apache ServiceMix 5的完整源码,用于开发、...

    org.apache.servicemix.bundles.xmlbeans-2.4.0_1.jar

    org.apache.servicemix.bundles.xmlbeans-2.4.0_1.jar

    apache-servicemix-4.4.0(1)

    【Apache ServiceMix 4.4.0 知识点详解】 Apache ServiceMix 是一个开源的企业级集成平台,基于 Java 应用服务器,它提供了一种轻量级、灵活的方式来实现企业应用集成(EAI)和面向服务架构(SOA)。在这款软件中,...

    apache-servicemix-4.4-fuseesb

    Apache ServiceMix是一个开源的企业服务总线(ESB),它基于Java EE规范,提供了一种集成不同应用程序和服务的平台。在标题"apache-servicemix-4.4-fuseesb"中,我们可以推断这可能是指Apache ServiceMix的4.4版本,...

    org.apache.servicemix.bundles.spring-aspects-3.2.8.RELEASE_2.zip

    标题中的"org.apache.servicemix.bundles.spring-aspects-3.2.8.RELEASE_2.zip"指示了这是一个与Apache ServiceMix相关的软件包,特别地,它包含了Spring框架的一个特定版本——3.2.8.RELEASE的面向切面编程(AOP)...

    org.apache.servicemix.bundles.juel-2.1.3_1.zip

    标题中的"org.apache.servicemix.bundles.juel-2.1.3_1.zip"是一个开源项目的压缩包,它包含的是Apache ServiceMix中的JUEL(Java Unified Expression Language)库的特定版本。JUEL是一个开源的Java实现,遵循JSR ...

    org.apache.servicemix.bundles.spring-test-3.2.8.RELEASE_2.zip

    标题中的"org.apache.servicemix.bundles.spring-test-3.2.8.RELEASE_2.zip"表明这是一个关于Apache ServiceMix的Spring测试框架的版本包。Apache ServiceMix是基于Java的全面企业级服务总线(ESB),它集成了许多...

    apache-servicemix-4.4-fuseesb第四部分

    Apache ServiceMix 和 Fuse ESB 是两个紧密相关的开源企业服务总线(ESB)项目,它们在集成、管理和路由企业应用程序间的数据交换方面扮演着重要角色。Apache ServiceMix 是基于 Java 的 ESB,它实现了多种服务导向...

    apache-servicemix-4.4-fuseesb第三部分

    Apache ServiceMix 和 Fuse ESB 是两个紧密相关的开源企业服务总线(ESB)项目,它们在集成和管理企业应用程序方面发挥着关键作用。Apache ServiceMix 是一个基于 Java 的 ESB,它利用了诸如 Apache Camel、CXF 和 ...

    org.apache.servicemix.specs.locator-2.3.0.zip

    java-game-server.zip,nadron是一个基于socket的高速java游戏服务器,使用netty和mike rettig的jetlang编写。它专门针对基于网络的多人游戏进行了调整,并支持TCP和UDP网络协议。

    apache-servicemix-3.3-src.zip

    Apache ServiceMix是一个开源的企业服务总线(ESB)和应用服务器,它基于Java EE和OSGi规范,提供了集成不同应用程序和服务的能力。这个压缩包“apache-servicemix-3.3-src.zip”包含了ServiceMix 3.3版本的源代码,...

Global site tag (gtag.js) - Google Analytics