到Mule的官方网站(http://mule.mulesource.org/display/MULE/Download)上下载Mule的最新稳定版,目前是1.3.3(http://www.mulesource.com/ccount/click.php?id=17),也可以使用社区版的1.4.1(http://www.mulesource.com/ccount/click.php?id=33)。本文档以1.3.3版为例,1.4.1请参照文档自行修改。
下载后得到一个ZIP格式的压缩文件mule-1.3.3.zip,将该文件解压至任一目录,假设为C:\mule-1.3.3,本文档以环境变量MULE_HOME表示该目录。
二、运行Echo示例
Mule自带了很多示例,从最简单的echo示例到一个比较完整的贷款中介服务loanbroker。每个示例程序都分为ant和maven两个版本,它们分别位于 %MULE_HOME%\examples\ant和 %MULE_HOME%\examples\maven目录下。文档将以ant版本为例说明如何运行echo示例。
1、到apache官方网站的ant项目下载页(http://ant.apache.org/bindownload.cgi)上下载ant1.7.0(http://apache.mirror.phpchina.com/ant/binaries/apache-ant-1.7.0-bin.zip),下载后将文件解压到任一目录(假设为C:\apache-ant-1.7.0,文档中表示为ANT_HOME环境变量)。
2、设置环境变量ANT_HOME到ant的解压目录,如:
ANT_HOME=C:\apache-ant-1.7.0
3、将%ANT_HOME%\bin加入到系统寻找路径中,如:
PATH=%ANT_HOME%\bin;%PATH%
4、启动命令行窗口,进入%MULE_HOME%\examples\ant\echo目录,执行下面命令:
echo.bat
示例程序会先显示一个License信息,输出一些日志记录,最终出现以下信息:
INFO 2007-08-29 16:54:44,062 [WrapperSimpleAppMain] org.mule.MuleManager:
**********************************************************************
* Mule ESB and Integration Platform version Not Set *
* Not Set *
* For more information go to http://mule.mulesource.org *
* *
* Server started: 2007年8月29日 星期三 下午04时54分42秒 CST *
* Server ID: Mule_Echo_Sample *
* JDK: 1.5.0_11 (mixed mode, sharing) *
* OS: Windows XP - Service Pack 2 (5.1, x86) *
* Host: zengfl (192.168.25.71) *
* *
* Agents Running: *
* Mule Admin: accepting connections on tcp://localhost:60504 *
**********************************************************************
INFO 2007-08-29 16:54:44,062 [WrapperSimpleAppMain] org.mule.MuleServer: Mule S
erver initialized.
Please enter something:
表示示例程序运行成功,随便输入一些字符,这些字符被回显出来的同时,回显的处理日志信息也被显示出来。
注意,在执行这个步骤时,请确信您能访问互联网,否则,示例程序无法运行。
三、一个简单的Mule Java Application
下面,以一个类似Echo的Java Application为例说明如何使用Mule来建立应用。后面会说明如何在Web应用程序中集成Mule。
1、在Eclipse中建立一个Java Application,为Application命令为MuleAppTest。
2、在Package Explorer视图中,选中刚刚建立的MuleAppTest项目,按下Alt+Enter键打开该项目的属性设置对话框,找到Java Build Path菜单,打开右边的Libraries标签页。
3、点击“Add External JARs...”按钮,将 %MULE_HOME%\lib\mule 目录和 %MULE_HOME%\lib\opt 目录下的所有jar文件添加到项目的库路径中(%MULE_HOME%\bin\opt目录下的jar文件并不是必须的,您可以根据需要选择您要加入的包,本文实际上只使用了与Web Service相关的一些库文件)。
4、在源码目录(src)下建立一个EchoService接口及其实现类EchoServiceImpl。
EchoService.java
package com.san.mule;
public interface EchoService {
public String echo(String s);
}
EchoServiceImpl.java
package com.san.mule;
public class EchoServiceImpl implements EchoService {
public String echo(String s) {
return s;
}
}
5、在源码目录(src)下建立一个mule-config.xml文件,为Mule配置入口端点,并将这个端点发布成一个基于axis的Web服务。
mule-config.xml
"http://mule.mulesource.org/dtds/mule-configuration.dtd">
implementation="com.san.mule.EchoServiceImpl">
address="axis:http://localhost:8181/services">
6、建立一个Mule的Application示例。
MuleAppTest.java
package com.san.mule;
import org.mule.config.ConfigurationException;
import org.mule.config.builders.MuleXmlConfigurationBuilder;
import org.mule.umo.manager.UMOManager;
public class MuleAppTest {
public static void main(String[] args) throws ConfigurationException {
MuleXmlConfigurationBuilder builder = new MuleXmlConfigurationBuilder();
UMOManager manager = builder.configure("mule-config.xml");
}
}
7、在MuleAppTest.java点击右键,选择Run As菜单中的Java Application运行MuleAppTest类。
8、打开浏览器,访问http://localhost:8181/services/echoService?wsdl,即可看见服务的描述信息。
9、我们来运行一下这个Web服务,看是否能正确运行,在浏览器地址栏中输入:
http://localhost:8181/services/echoService?method=echo¶m=zengfl
四、在Web Application中集成Mule
继续前面的项目,我们将Mule集成到Tomcat的一个Web Application中,并使用一个JSP页面来访问Mule组件。
1、在项目中建立Web Application的相关目录WEB-INF、WEB-INF\lib和WEB-INF\classes。
2、将%MULE_HOME%\lib\mule目录和%MULE_HOME%\lib\opt目录下的所有文件复制到项目的WEB-INF\lib目录下。
将%MULE_HOME%\lib\user\activation.jar和%MULE_HOME%\lib\user\mail.jar两个文件复制到项目的WEB-INF\lib目录下。(注意,如果你没有找到这两个文件,那是因为你没有成功运行第二节中的测试程序。)
3、将项目的output folder设置成项目的WEB-INF/classes目录。
4、将项目src目录下的mule-config.xml文件复制到项目的WEB-INF目录下。
注意,当你把项目的output folder设置成WEB-INF/classes时,该目录会从Package Explorer中消失,这是正常现在,你可以在Navigator视图中找到这个目录。
5、建立WEB-INF\web.xml文件。
web.xml
org.mule.config.builders.MuleXmlBuilderContextListener
org.mule.providers.http.servlet.MuleReceiverServlet
6、建立一个测试页面echo.jsp
<%@ page language="java" contentType="text/html; charset=UTF-8"%>
<%@ page import="org.mule.extras.client.MuleClient" %>
<%@ page import="org.mule.umo.UMOMessage" %>
<%
String s = request.getParameter("name");
if (s != null) {
MuleClient client = new MuleClient();
UMOMessage message = client.send(
"axis:http://localhost:8181/services/echoService?method=echo",
s, null);
%>
<%=message.getPayload()%>
<%
}
%>
你的名字:
7、将项目部署到%TOMCAT_HOME%\webapp目录下,启动Tomcat,访问
http://localhost:8080/MuleAppTest/echo.jsp
输入你的名字测试一下,OK。