Apache Camel的multicast简单示例

这里以一个问题开始:

<from uri="direct:multicast" />
<multicast>
<to uri="direct:s1" />
<to uri="direct:s2" />
<to uri="direct:s3" />
</multicast>

和

<from uri="direct:multicast" />
<to uri="direct:s1" />
<to uri="direct:s2" />
<to uri="direct:s3" />

有什么区别?


回答:

加了multicast后,消息会复制多份,发送到后面所有的to节点,multicast可以指定线程池来并发,发送消息 没加的话,消息会依次流转到后面的节点

<bean id="bean1" class="com.pp.bean.Bean2">
	<property name="str" value="123"></property>
</bean>
<bean id="bean2" class="com.pp.bean.Bean2">
	<property name="str" value="456"></property>
</bean>

<bean id="changeInfo" class="com.pp.bean.Bean3" />

<camelContext id="camelContext" xmlns="http://camel.apache.org/schema/spring">
	<template id="camelTemplate" />

	<route autoStartup="true">
		<from uri="timer://aaa?fixedRate=true&period=60000" />
		<multicast>
			<to uri="bean1" />
			<to uri="changeInfo" />
			<to uri="bean2" />
		</multicast>
	</route>

	<route autoStartup="false">
		<from uri="timer://aaa?fixedRate=true&period=60000" />
		<to uri="bean1" />
		<to uri="changeInfo" />
		<to uri="bean2" />
	</route>

</camelContext>

package com.pp.bean;

import org.apache.camel.Exchange;
import org.apache.camel.Processor;

public class Bean2 implements Processor 
{
	private String str;
	public void process(Exchange exchange) throws Exception 
	{
		System.out.println("+++++++++++++"+str+"+++++++++++++");
		System.out.println(exchange.getIn().getHeaders());
		System.out.println(exchange.getProperties());
		System.out.println("+++++++++++++"+str+"+++++++++++++");
	}
	public String getStr() {
		return str;
	}
	public void setStr(String str) {
		this.str = str;
	}
}

package com.pp.bean;

import org.apache.camel.Exchange;
import org.apache.camel.Processor;

public class Bean3 implements Processor 
{
	public void process(Exchange exch) throws Exception
	{
		exch.getIn().setHeader("add_header", "111");
		exch.setProperty("add_property", "HTTPS");
	}
}

分别运行,这2个route,即可发现效果

第一个route中的changeInfo后,并没有反应到下面的节点中去,第二个就反应到下面的节点中去了

  • 5
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值