微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

ServiceMix做代理服务器发布WebService(附带案例源码)

最近公司让自己研究Servicemix对于它比较陌生,把自己学习的经验记录下来,如果对您有用你可以借鉴

:首先我们需要了解一下相关概念,什么SOA,什么是ESB
面向服务的体系结构(Service-Oriented ArchitectureSOA)是一个组件模型,它将应用程序的不同功能单元(称为服务)通过这些服务之间定义良好的接口和契约联系起来。

   
接口是采用中立的方式进行定义的,它应该独立于实现服务的硬件平台、操作系统和编程语言。这使得构建在各种这样的系统中的服务可以一种统一和通用的方式进行交互。
这是完整的定义:
1
一个组件模型

2 不同功能单元,称为服务

3 服务之间通过接口和约定联系起来

4 接口是中立的

ESB全称为Enterprise Service Bus,即企业服务总线。它是传统中间件技术与XMLWeb服务等技术结合的产物。ESB提供了网络中最基本的连接中枢,是构筑企业神经系统的必要元素。

ESB的出现改变了传统的软件架构,可以提供比传统中间件产品更为廉价的解决方案,同时它还可以消除不同应用之间的技术差异,让不同的应用服务器协调运作,实现了不同服务之间的通信与整合。

功能上看,ESB提供了事 件驱动和文档导向的处理模式,以及分布式的运行管理机制,它支持基于内容的路由和过滤,具备了复杂数据的传输能力,并可以提供一系列的标准接口。

Servicemix是什么?

Servicemixapache发布的一种ESB

Servicemix上服务的实现

Servicemix上可以直接发布WebservicePOJOs之类的程序或者模块,也可以发布一个类似于代理的服务。

从流程上来说:Servicemix使用consumer接受到客户request,在Servicemix的服务列表中寻找服务,并且发布一个EndPoint,然后再provider中发布一个指向目标service的服务。

Service Unit    Service Assembly

如字面意思,service unit就是一个一个的服务单元,而service assembly是这些单元的集合

servicemix上发布一项服务,其实是发布一个服务集(SA)在这个集合中,可能存在一个或者多个服务(SU)

例如,我们有一个服务需要顺序使用两个webservice,那个我们可以定义两个SU分别对应不同的webservice,然后使用一个SA将这两个SU统合起来

这样,我们就可以调用一个暴露在外面的服务(该SA的服务),来达到使用两个webservice的目的

我们的目标是让Servicemix充当一个Proxy,即将一个外部的WebService发布到ServiceMix服务当中。使得客户可以通过调用暴露在外面的Servicemix的服务端口来调用实际上在其他服务器上的 WebService

实现这个目标,可以通过两种组件完成。

1Servicemix-Http-bc

2Servicemix-CXF-bc

Http-bc的优点是使用范围非常的广,缺点是使用非常麻烦。也就是说大多数组件都要我们自己定义。

Cxf-bc的优点是比较简单。这个组件本身集成了对现有大多数Soap/Http形式的支持,对于没有特定要求的使用来说是足够了。

顺便一提Http-seCxf-se,这两个是相对于上面两个而言的,这两个是服务引擎,对象一般是实际的Class或者Application

Servicemix的教程参考:

http://servicemix.apache.org/tutorials.html

CXF教程参考:

http://servicemix.apache.org/4- beginner-web-services-with-servicemix-and-cxf.html

本文使用CXF-bc来实现,参考:http://servicemix.apache.org/servicemix-cxf- bc.html

第一步:开发所需要的所有工具以及环境:(包括4个)

1apache-servicemix-3.2.2  

http://servicemix.apache.org/download.html

配置环境 :变量名称                         变量的值

SERVICEMIX_HOME          apache-servicemix-3.2.2解压目录(D:/apache-servicemix-3.3.2

Path                          %sERVICEMIX_HOME%/bin

2apache-Maven 2.0以上版本

http://maven.apache.org/download.html

配置环境 :变量名称                         变量的值

 M2_HOME                         解压Maven的目录(D:/apache-maven-2.2.1)

 M2                               %M2_HOME%/bin

MAVEN_OPTS                     -xms256m -Xmx512m

Path                               %M2%

3JDK1.5以上版本(配置好环境变量)

4apache-tomcat-6.0.29 

       5.测试:在CMD下,Servciemix安装目录下 D

       cd apache-servicemix-3.3.2

`     bin/servicemix 启动servicemix

在地址栏输入 http://localhost:8192/ 看是否成功启动

第二步:LoginDemo 登录案例

 

分两步

1.建立一个WebService

2.将该WebService发布到Servicemix里面

1打开MyEclipse –File –New –WebServiceProject

下一步:

 

再下一步

 

 

2 在工程目录下建立一个名称 org.xinyu.web 如图

 

 

 

 

 

 

 

直接部署到Tomcat 下面 ,并进行发布

 

到这里第一步完成,同样可以采用Ajax2进行发布效果一样

 

 

 

2 新建一个Servicemix的组件  在任意路径下建一个项目工程的目录

示例 如: E:/Login

运行cmd,进入该目录,执行

mvn archetype:create -DarchetypeGroupId=org.apache.servicemix.tooling -DarchetypeArtifactId=servicemix-project-root -DgroupId=org.apache.servicemix.tutorial -DartifactId=tutorial-wsdl-cxf-service

用来创建一个标准的pom.xml

在这pom.xml中,对于一些基本的工程配置作了设定

 

得到信息如下:

 

 

在我们成功建立了之后,会发现Login文件夹下面多出了一个路径  则我们在这个新建的路径下面运行

mvn install

 

 

 

 

 

 

 至此,我们已经将这个新建的工程发布到我们的本地 Maven repository

       下面我们建立一个CXF-BC Service Unit

        在我们刚才建立的工程文件夹下面,运行

mvn archetype:create -DarchetypeGroupId=org.apache.servicemix.tooling -DarchetypeArtifactId=servicemix-cxf-bc-service-unit -DgroupId=org.apache.servicemix.examples -DartifactId=my-cxf-bc-su

 

 

 

 

 

至此,我们建议了一个标准的CXF-BC-SU组件的框子

  现在进入新建的组件的文件夹。

然后我们需要将我们发布在tomcat上的Webservicewsdl复制下来放入servicemix这个bc组建之中。

  关于wsdl文件

  打开wsdl文件,我们可以发现,wsdl其实定义了webservice的所有规范,例如它的名字,接 口,方法,参数等等   而我们需要将wsdl复制到我们要发布的servicemix当中,是因为我们暴露出去的接口,方法 参数等要能和  实际服务的webservice一致。所以servicemix当中需要一个由同样接口定义的wsdl

 

 

 访问http://localhost:8080/LoginDemo/services/LoginService?wsdl   

 

  得到我们刚才发布的webservicewsdl文件

将这个wsdl文件复制到%/my-cxf-bc-su/src/main/resources 

        其实这里原本就预订了一个wsdl文件的位置。

        注意,我的wsdl名字叫做Login.wsdl,因此,当复制过来后,原来的service.wsdl就可以删除

        当然,我们也可以把刚才myecilpse项目中生成wsdl复制过来,这是一样的文件

       然后 现在我们需要修改这个复制进来的wsdl文件 如下

       <wsdl:service name="LoginServiceProxy">

    <wsdl:port name="LoginProxy" binding="tns:LoginServiceHttpBinding">

      <wsdlsoap:address location="http://localhost:8192/Login/"/>

    </wsdl:port>

 </wsdl:service>

 

 

 

 

在我们已经完成了对wsdl的设定,现在我们需要在xbean.xml设定consumerprovider来帮定这些东西。 

xbean.xml,作如下修改

 首先,我们需要一个namespace,这个namespace要和我们引用的wsdl中的service endpointnamespace一致,这样我们才能准确找到service和接口

我们的wsdl定义的targetNamespace=http://web.xinyu.org

所以我们bc组件中的consumerprovider定义的namespace也必须和上面一样

现在来定义consumerprovider,基本的定义规则参照:http://servicemix.apache.org/servicemix-cxf-bc.html

       <cxfbc:consumer wsdl="classpath:Login.wsdl"

                     service="ws:LoginServiceProxy"

                     endpoint="ws:LoginProxy"

                     targetService="ws:LoginService"

                     targetEndpoint="ws:Login"

              />   

 

    <cxfbc:provider wsdl="http://localhost:8080/LoginDemo/services/LoginService?WSDL"

                     service="ws:LoginService"

                     endpoint="ws:Login"

          />

 

 

注:这里采用轻量级模式,即,将consumerprovider写在一个service unit内,如果想在中间加入其它程序,则可以将 consumerprovider分成两个service unit

这样service unit就建好了,接下来我们建立service assembly

在我们的工程路目下运行

 

mvn archetype:create -DarchetypeGroupId=org.apache.servicemix.tooling -DarchetypeArtifactId=servicemix-service-assembly -DgroupId=org.apache.servicemix.examples -DartifactId=my-cxf-sa

 

 

 

 现在可以看到工程目录中新建出来了SA文件

   接下来,我们要在这SA注册我们刚才制作的SU,进入SA修改pom.xml

    <dependencies>

              <dependency>

              <groupId>org.apache.servicemix.examples</groupId>

              <artifactId>my-cxf-bc-su</artifactId>

              <version>1.0-SNAPSHOT</version>

              </dependency>

  </dependencies>

 好了现在一切就绪,我们在工程目录下面运行

mvn install l

 

  

 

 

 

  build successful之后,我们就可以在

 %/my-cxf-sa/target

        目录下面看到我们建立好的jar

 将这个zip包复制到servicemix目录下面的/hotdeploy文件夹,来正式发布到servicemix当中

 

 

 

 

看到如此信息则,发布成功

http://localhost:8192/Login/?wsdl 输入地址进行访问 。整个发布过程已经成功 ,客户端测试代码

在工程里面新建一个包名为client的包,新建一个 LoginTest

 

测试结果

 

 

到这里就结束了,大家要源码可以到我上传的资源中去下载这边不好传。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。

相关推荐