首先我们需要了解一下相关概念,什么SOA,什么是ESB
面向服务的体系结构(Service-Oriented Architecture,SOA)是一个组件模型,它将应用程序的不同功能单元(称为服务)通过这些服务之间定义良好的接口和契约联系起来。
接口是采用中立的方式进行定义的,它应该独立于实现服务的硬件平台、操作系统和编程语言。这使得构建在各种这样的系统中的服务可以一种统一和通用的方式进行交互。
这是完整的定义:
1 是一个组件模型
2 不同功能单元,称为服务
3 服务之间通过接口和约定联系起来
4 接口是中立的
ESB全称为Enterprise Service Bus,即企业服务总线。它是传统中间件技术与XML、Web服务等技术结合的产物。ESB提供了网络中最基本的连接中枢,是构筑企业神经系统的必要元素。
ESB的出现改变了传统的软件架构,可以提供比传统中间件产品更为廉价的解决方案,同时它还可以消除不同应用之间的技术差异,让不同的应用服务器协调运作,实现了不同服务之间的通信与整合。
从功能上看,ESB提供了事 件驱动和文档导向的处理模式,以及分布式的运行管理机制,它支持基于内容的路由和过滤,具备了复杂数据的传输能力,并可以提供一系列的标准接口。
Servicemix是什么?
Servicemix是apache发布的一种ESB。
参考官方页http://servicemix.apache.org
Servicemix上服务的实现
Servicemix上可以直接发布Webservice和POJOs之类的程序或者模块,也可以发布一个类似于代理的服务。
从流程上来说: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。
实现这个目标,可以通过两种组件完成。
1,Servicemix-Http-bc
2,Servicemix-CXF-bc
Http-bc的优点是使用范围非常的广,缺点是使用非常麻烦。也就是说大多数组件都要我们自己定义。
Cxf-bc的优点是比较简单。这个组件本身集成了对现有大多数Soap/Http形式的支持,对于没有特定要求的使用来说是足够了。
顺便一提Http-se和Cxf-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
所需工具:
apache-Servicemix-3.2.2 release (据官方说,开源变化很大,最新的比较完备,至少需要3.2以上版本)
http://servicemix.apache.org/download.html
apache-Maven 2.0以上版本
http://maven.apache.org/download.html
JDK1.5以上版本
apache-axis2
http://ws.apache.org/axis2/download.cgi
apache-tomcat
apache eclipse wsdl 插件(Service Archive Wizard - Eclipse Plug-in,Code Generator Wizard - Eclipse Plug-in等)
http://ws.apache.org/axis2/tools/index.html
示例:
1,安装好JDK,并且配置好JDK的环境变量
2,安装好Maven,并且配置好Maven的环境变量
环境变量:
M2_HOME : ; 解压Maven的目录
M2: ; &nbs p;M2_HOME%/bin
MAVEN_OPTS : - Xms256m -Xmx512m
Path: ; %M2%
3,安装好Servicemix
测试:在CMD下,Servciemix安装目录下
运行
cd bin
servicemix
则服务器启动
在http://localhost:8192/可以看到服务器已经在运行。
4,安装好Tomcat,并且配置好环境变量
5,安装好Axis2,并且配置好环境变量
注:这里可以使用简单方式,下载Axis2的war包,直接发布到Tomcat中就可以。
测试:http://localhost:8080/下检查新添加的Axis2服务
6,将Service Archive Wizard - Eclipse Plug-in等插件装进Eclipse
注:这些插件不是必要的,仅仅可以使工作变得简单一些。
7,打开Eclipse并新建动态Web工程(Eclipse需要WTP插件)
输入Project名字HelloWorld,然后点击finish
8,在新建的工程中添加class
在新建的project的src中添加一个package
package名字为sample
在该包中添加一个class
Class的名字为Hello,点击Finish
修改java文件的内容如下。
9,生成wsdl文件
这里可以用Code Generator Wizard - Eclipse Plug-in插件生成,也可以用其他插件生成,差别不大
以上两种方法都可以,第二种只要按照提示来就可以了,分别是选择class,选择生成路径
下面说第一种方法