mule
它是一个以Java为核心的轻量级的消息框架和整合平台,基于EIP(Enterprise Integeration Patterns,由Hohpe和Woolf编写的一本书)而实现的。Mule的核心组件是UMO(Universal Message Objects,从Mule2.0开始UMO这一概念已经被组件Componse所代替),UMO实现整合逻辑。UMO可以是POJO,JavaBean 等等。它支持30多种传输协议(file,FTP,UDP,TCP,email,HTTP,SOAP,JMS等),并整合了许多流行的开源项目,比如 Spring,ActiveMQ,CXF,Axis,Drools等。虽然Mule没有基于JBI来构建其架构,但是它为JBI容器提供了JBI适配器, 应此可以很好地与JBI容器整合在一起。而 Mule更关注其灵活性,高效性以及易开发性。从2005年发表1.0版本以来,Mule吸引了越来越多的关注者,成为开源ESB中的一支独秀。目前许多 公司都使用了Mule,比如Walmart,HP,Sony,Deutsche Bank 以及 CitiBank等公司。Mule 3版本以后集成OSGi,支持热部署。
可见OSGI必将是将来的一大趋势,各大厂商,开源软件等都已经开始支持此规范。
下载和安装Mule ESB
我们到Mule的官方网站下载Mule ESB,网站是:
Mule一共有两个版本,一个是社区版,一个是企业版,企业版是收费的,但是功能强大。
图:Mule ESB社区版
图:Mule ESB企业版
我们下载社区版。
然后解压、启动Mule Studio,选择工作空间:
图:Mule Studio启动并运行
基础示例
启动并且选择默认的工作空间后,就会出现如下界面:
图:Mule Studio的欢迎界面
创建新工程:File > New > Mule Project
因为我们要做的示例是拼写检查,所以我们这里命名叫SpellChecker
图:创建Mule工程
其它默认,下一步然后完成。
工程界面如下:
图:Mule Studio工作界面
接下来我们为示例设置两个文件夹:
选择Studio Application Menu > File > Open File >
然后打开你的Mule Studio安装文件夹,Examples > Spell Checker
新增目录InXML和OutXML
图:在目录中新加文件夹
下面看下典型的业务流程:
图:业务流程图
web客户端发送Http请求然后到入口端点,经过Filter进行过滤错误的信息,然后转换成JMS的服务,经过Java的业务逻辑组件处理最后再转换成Http请求返回给客户端应用,就是这么样的一个流程。
下面我们就Mule Studio来画一下对应的应用,直接看完成后的效果:
图:spell checker处理流程
双击第一个File,设置上边新建的输入文件夹:
图:设置输入的文件夹
然后双击Http标签,设置如下:
图:http设置
最后设置File的输出规则:
图:File的输出规则及输出目录
保存文件,然后我们运行工程,工程上点右键,Run As > Mule Application
正常启动后应该能看到
图:Mule启动运行spellchecker
图:spellcheck文件的位置
将示例中spellcheck拷贝到InXML中,然后我们看Mule的控制台
图:Mule控制台的信息
我们再看一下OutXML文件夹,多了一个生成后的文件
上面就是Mule的示例工程,看看Mule有多好用吧!