Apache Camel提供了和Spring的集成,通过Spring容器(ApplicationContext)来管理Camel的CamelContext,这样的话,就不需要写代码来控制CamelContext的初始化,启动和停止了.Camel会随着Spring的启动而启动起来.
本文将Apache Camel框架入门示例(http://blog.csdn.net/kkdelta/article/details/7231640)中的例子集成到Spring中,下面简单介绍一下集成的基本步骤.
1,新建一个Eclipse工程,将Spring3的jar包,和Camel的jar包配置到工程的classpath.
2,Route类要继承RouteBuilde,如下
1 | public class FileProcessWithCamelSpring extends RouteBuilder { |
3 | public void configure() throws Exception { |
4 | FileConvertProcessor processor = new FileConvertProcessor(); |
5 | from("file:d:/temp/inbox?delay=30000").process(processor).to("file:d:/temp/outbox"); |
3,Processor仍然和和入门示例的代码相同.
01 | public class FileConvertProcessor implements Processor{ |
03 | public void process(Exchange exchange) throws Exception { |
05 | InputStream body = exchange.getIn().getBody(InputStream.class); |
06 | BufferedReader in = new BufferedReader(new InputStreamReader(body)); |
07 | StringBuffer strbf = new StringBuffer(""); |
11 | System.out.println(str); |
12 | strbf.append(str + " "); |
15 | exchange.getOut().setHeader(Exchange.FILE_NAME, "converted.txt"); |
17 | exchange.getOut().setBody(strbf.toString()); |
18 | } catch (IOException e) { |
4,创建一个Spring的配置文件如下:注意要将camel的xmlns加入文件中
01 | xml version="1.0" encoding="UTF-8"?> |
02 | <beans xmlns="http://www.springframework.org/schema/beans" |
03 | xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" |
04 | xmlns:camel="http://camel.apache.org/schema/spring" |
05 | xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-3.0.xsd |
06 | http://camel.apache.org/schema/spring http://camel.apache.org/schema/spring/camel-spring.xsd" |
07 | default-autowire="byName" default-init-method="init"> |
08 | <camelContext id="testCamelContext" xmlns="http://camel.apache.org/schema/spring"> |
09 | <package>com.test.camel</package> |
5,启动Spring容器,Camel会自动启动,不用像入门示例那样CamelContext context = new DefaultCamelContext(), context.addRoutes(..); context.start();
ApplicationContext ac = new ClassPathXmlApplicationContext("config/cameltest.xml");
while (true) {
Thread.sleep(2000);
}
可见,Camel可以很容易的和Spring集成.
Camel还提供了"Spring DSL"来在XML中配置Route规则,不需要用JAVA类(如上面的FileProcessWithCamelSpring )来实现route.
01 | xml version="1.0" encoding="UTF-8"?> |
02 | <beans xmlns="http://www.springframework.org/schema/beans" |
03 | xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" |
04 | xmlns:camel="http://camel.apache.org/schema/spring" |
05 | xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-3.0.xsd |
06 | http://camel.apache.org/schema/spring http://camel.apache.org/schema/spring/camel-spring.xsd" |
07 | default-autowire="byName" default-init-method="init"> |
08 | <bean id="fileConverter" class="com.test.camel.FileConvertProcessor"/> |
09 | <camelContext id="testCamelContext" xmlns="http://camel.apache.org/schema/spring"> |
11 | <from uri="file:d:/temp/inbox?delay=30000"/> |
12 | <process ref="fileConverter"/> |
13 | <to uri="file:d:/temp/outbox"/> |
与第五步一样启动Spring容器,Camel会每隔30秒轮询一下看d:/temp/inbox是否有文件,有的话则进行处理.
Comments
Post a Comment