rabbitMq的TopicExchange方式推送配置

//application.yml 文件配置

rabbitmq:
      host: 116.62.155.356
      port: 5672
      username: asdad
      password: 1232456

以下发送者与接收者需要分别建立两个工程作为发送端与接收端,不能配置在一个工程里。

//接受者配置
@Configuration
public class RabbitConfig {

	@Bean
	public Queue queueMessages() {
		return new Queue("testt1");
	}

	@Bean
	TopicExchange exchange() {
		return new TopicExchange("topic.message");
	}

	/**
	 * 将队列testt1与exchange绑定,binding_key为topic.message,就是完全匹配
	 * @param queueMessage
	 * @param exchange
	 * @return
	 */
	@Bean
	Binding bindingExchangeMessage(Queue queueMessage, TopicExchange exchange) {
		return BindingBuilder.bind(queueMessage).to(exchange).with("topic.message");
	}
}

 

//接受者
@Component
@RabbitListener(queues = "testt1")
public class HelloReceiver {
	@RabbitHandler
	public void process(String hello) {
		System.out.println("Receiver  : " + hello);
	}
}

 发送者配置exchange管理

//发送者配置
@Configuration
public class RabbitConfig {

	@Autowired
	private RabbitTemplate rabbitTemplate;

	@Bean
	RabbitAdmin exchange() {
		RabbitAdmin admin = new RabbitAdmin(rabbitTemplate.getConnectionFactory());
		admin.declareExchange(new TopicExchange("topic.message"));
		return admin;
	}


}
//发送者
@Component
public class Sender1 {
	/**
	 * 注入AmqpTemplate,然后利用AmqpTemplate向一个名为hello的消息队列中发送消息。
	 */
	@Autowired
	private AmqpTemplate rabbitTemplate;
	public void send(){
		String msg="hello rabbitMQ:"+new Date()+" 你好,高级消息队列使用ing~";
		System.out.println("单对单发送参数。Sender发出了消息:"+msg);
//		this.rabbitTemplate.convertAndSend("hello",msg);
		// 第一个参数表示交换机,第二个参数表示routing key,第三个参数即消息,Topic方式
		 this.rabbitTemplate.convertAndSend("topic.message","routing key",msg);
	}

}

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 4
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值