前言

        发现JBossESB网上流传甚广的就是JBoss学习笔记系列了,这个系列资料还可以,但如果你一上来就看这个的话,感觉还是有点蒙,因为根本不明白这样做到底是为什么。所以看了之后,也会发现自己只能照着葫芦画一个葫芦,连一个瓢也画不了。

        helloworld这句话从我们一进行编程的世界就经常听到,那么第一个例子,我们就来helloworld。

ESB目录结构

        ESB发布之后,会是一个.esb格式的zip压缩包,里面的结构如下:

                        

esb怎么实现程序互通 esb接口开发教程_配置文件

        其中:

                jboss-esb.xml:包含service、listener、action、provider的配置,具体都是什么,后面会说到的。

                deployment.xml:是可选的,有两种情况下会用这个。一种是一个.esb依赖令一个.esb,用来指定加载顺序,另一种就是确定.esb的部署范围。不明白没关系,有的是例子使你明白这个的用处的。

                java classes:是你自己的包含包层次的action

                jars:这个我想不用说吧,就是添加你的应用依赖的包

                queue-service.xml:如果你的jboss-esb.xml中的provider使用的queue或者topic,你可以在通过这个来进行部署。使用其它方式督署也可以,不过ESB的官方文档中明确说明的建议采取此种方式。

运行helloworld


        在JBossESB的doc里面的Getting Started的最后面列出了一个学习JBossESB的学习建议。网上的JBossESB学习笔记大概就是按照这个顺序来进行的,有一些不同,但不碍事。


        在最初,我其实不太建议自己去敲,因为你还很不熟悉,直接运行它自己带的例子就好。


        运行需要安装Ant,Ant的安装很简单。提到Ant,不得不说一下。JBossESB是用的Ant构建的,所以最近和Ant打的交道特别多,最初感觉Ant没啥,现在感觉里面需要学习的东西很多,最近没事学习一下这个小东西。前面的博客对这个对这个进行过说明,这里不再重复。


        首先启动服务器,这里在JBossESB_Home/bin下的run.bat,不过建议新建一个start.bat,然后在里面写上run -b 0.0.0.0,这样写,就可以监听所有的IP了,不然,你的服务只能用localhost或者127.0.0.1访问(JBoss应用服务器首页也是这样的)。


        命令行下进入JBossESB_HOME/sample/quickstart/helloworld,然后运行ant deploy,成功后,再执行ant runtest;还可以执行ant sendesb执行,两个执行的结果是一样的,但原理却差好多。


helloworld配置解析


        action的代码很简单,所以就不做什么解析了,列一下代码得了,需要说的就是配置以及执行流程。


        

public class MyJMSListenerAction extends AbstractActionLifecycle
{
    
  protected ConfigTree	_config;
	  
  public MyJMSListenerAction(ConfigTree config) { _config = config; } 
  
  public Message displayMessage(Message message) throws Exception{
		
		  System.out.println("&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&");		  		  
		  System.out.println("Body: " + message.getBody().get()) ;
		  System.out.println("&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&");
		  return message; 
        		
	}
}


        怎样写Action,自己查文档吧,没啥意思。



jboss-esb.xml


        在这个里面有provider、service、listener、action。


        provider是对外提供的一个入口,不论是ESB(aware)还是非ESB(aware)都可以通过这个进入。


        listener是对provider进行监听的一个东西。通过它能够获取到发到provider上的东西。


        service是对外发布的服务,我感觉是对action的一个整理。


        action是一个又一个的动作。可大可小(粒度),就看你是怎样设计的。


        看完这些基本的概念,那么现在来看一下官方提供的权威例子吧。




<?xml version = "1.0" encoding = "UTF-8"?>
<jbossesb xmlns="http://anonsvn.labs.jboss.com/labs/jbossesb/trunk/product/etc/schemas/xml/jbossesb-1.0.1.xsd" parameterReloadSecs="5">

    <providers>
          <jms-provider name="JBossMQ" connection-factory="ConnectionFactory">
              <jms-bus busid="quickstartGwChannel">
                  <jms-message-filter
                      dest-type="QUEUE"
                      dest-name="queue/quickstart_helloworld_Request_gw"
                   />
              </jms-bus>
              <jms-bus busid="quickstartEsbChannel">
                  <jms-message-filter
                      dest-type="QUEUE"
                      dest-name="queue/quickstart_helloworld_Request_esb"
                  />
              </jms-bus>

          </jms-provider>
      </providers>
      
      <services>
        <service 
        	category="FirstServiceESB" 
        	name="SimpleListener" 
        	description="Hello World">
            <listeners>
                <jms-listener name="JMS-Gateway"
                    busidref="quickstartGwChannel"
                    is-gateway="true"
                />
                <jms-listener name="helloWorld"
                              busidref="quickstartEsbChannel"
                />
            </listeners>
            <actions mep="OneWay">
                   <action name="action1" 
                   	class="org.jboss.soa.esb.samples.quickstart.helloworld.MyJMSListenerAction" 
                   	process="displayMessage" 
                   	/>      
                    <action name="action2" class="org.jboss.soa.esb.actions.SystemPrintln">
                      <property name="printfull" value="false"/>
                    </action>
                    <!-- The next action is for Continuous Integration testing -->
                    <action name="testStore" class="org.jboss.soa.esb.actions.TestMessageStore"/>
            </actions>
        </service>
      </services>
     
</jbossesb>




        大家发现了么,在一个jms-provider里面使用了两个jms-bus,而且除了名字其它都一样。但监听它们的listoner配置是不一样的,那就是is-gateway="true",这个区别了,is-gateway的默认值为false。被设置这个属性为true的才能监听来自非ESB(Unaware)发过来的消息,否则只能监听ESB消息(Aware,采用ServiceInvoker调用)。


        下面,咱们来看一下官方文档中给的一个helloworld中给出的执行流程的一个图:


        

esb怎么实现程序互通 esb接口开发教程_xml_02


        有了这一张原理图,是不是好些了呢?那么我们继续来看后几个吧。


jbm-queue-service.xml


<?xml version="1.0" encoding="UTF-8"?>
<server>
  <mbean code="org.jboss.jms.server.destination.QueueService"
    name="jboss.esb.quickstart.destination:service=Queue,name=quickstart_helloworld_Request_esb"
    xmbean-dd="xmdesc/Queue-xmbean.xml">
	<depends optional-attribute-name="ServerPeer">jboss.messaging:service=ServerPeer</depends>
	<depends>jboss.messaging:service=PostOffice</depends>
  </mbean>
  <mbean code="org.jboss.jms.server.destination.QueueService"
    name="jboss.esb.quickstart.destination:service=Queue,name=quickstart_helloworld_Request_gw"
    xmbean-dd="xmdesc/Queue-xmbean.xml">
    <depends optional-attribute-name="ServerPeer">jboss.messaging:service=ServerPeer</depends>
	<depends>jboss.messaging:service=PostOffice</depends>
  </mbean>
</server



        如果你看sample/quickstart/helloworld下面,还有一个jbmq-queue-service.xml,但部署文件里只有jbm-queue-service.xml。

        下面是jbmq-queue-service.xml的配置信息:


<?xml version="1.0" encoding="UTF-8"?>
<server>
  <mbean code="org.jboss.mq.server.jmx.Queue"
    name="jboss.esb.quickstart.destination:service=Queue,name=quickstart_helloworld_Request_esb">
    <depends optional-attribute-name="DestinationManager">
      jboss.mq:service=DestinationManager
    </depends>
  </mbean>
  <mbean code="org.jboss.mq.server.jmx.Queue"
    name="jboss.esb.quickstart.destination:service=Queue,name=quickstart_helloworld_Request_gw">
    <depends optional-attribute-name="DestinationManager">
      jboss.mq:service=DestinationManager
    </depends>
  </mbean>
</server>



        jbm-queue-service.xml是JBoss messaging这种消息使用方式采用的配置文件,jbmq-queue-service.xml是JBossMQ的配置文件,但官方建议我们使用JBoss messaging,具体原因还待日后研究,只能说时间和精力有限啊。。。

        那么剩下的就是对QUEUE的定义了,privide中用到的QUEUE和Topic都需要在这里面进行一下定义。使用方法就照葫芦画一个瓢吧。


deployment.xml


<jbossesb-deployment>
  <depends>jboss.esb.quickstart.destination:service=Queue,name=quickstart_helloworld_Request_esb</depends>
  <depends>jboss.esb.quickstart.destination:service=Queue,name=quickstart_helloworld_Request_gw</depends>
</jbossesb-deployment>



        上面说过两种情况你会用到这个东西,esb部署上来需要使用到QUEUE或Topic,也就是说QUEUE这些东西是需要在程序部署上来之前就创建好。我感觉这个只是说明一下顺序,而创建工作是jbm-queue-service.xml这个配置文件中做的事情。

结语


        至此,helloworld中用到的配置文件就说完了。我是看完官方给的所有PDF后才开始看这些源码的,再加上JBossESB学习笔记系列的一些简单说明,现在感觉看例子什么的比之前好多了,但是还是有一些数据库之类的配置真心让人感觉很不爽,而且还有一些概念目前没有时间和精力来细研究,这块的学习继续进行~~后面陆续会有一些相对综合的文章。