rabbitmq的direct和fanout模式

rabbitmq的direct和fanout模式

流程:

  1. 请求链接并发送mq
  2. 消费者获取mq并处理

请求链接并发送mq
controller(IndexController):

@Autowired
private IndexService indexService;

@ResponseBody
@RequestMapping(value="/direct")
public void direct(){
log.info("[rabbitmq][direct][start]");
indexService.sendDirect();
log.info("[rabbitmq][direct][end]");
}

@ResponseBody
@RequestMapping(value="/fanout")
public void fanout(){
log.info("[rabbitmq][fanout][start]");
indexService.sendFanout();
log.info("[rabbitmq][fanout][end]");
}

service(IndexService):

@Resource(name = "direct-template")
private RabbitTemplate templateDirect;
@Resource(name = "fanout-template")
private RabbitTemplate fanoutDirect;

public void sendDirect(){
Message message = new Message<>();
message.setAction("DIRECT_TEST");
message.setData("DIRECT");
log.info("Message:"+message.getData());
templateDirect.convertAndSend(message);
}

public void sendFanout(){
Message message = new Message<>();
message.setAction("FANOUT_TEST");
message.setData("FANOUT");
log.info("Message:"+message.getData());
fanoutDirect.convertAndSend(message);
}

消费者获取mq并处理:
1.direct 方式


<rabbit:direct-exchange name="directExchange"
auto-declare="true" auto-delete="false" durable="true" declared-by="mqAdmin">
rabbit:bindings
<rabbit:binding queue="directQueue" key="directRoutekey" />
</rabbit:bindings>
</rabbit:direct-exchange>
<rabbit:queue name="directQueue"
auto-declare="true" auto-delete="false"
durable="true" declared-by="mqAdmin" />

<rabbit:template id="direct-template"
connection-factory="mqConnectionFactory"
queue="directQueue"
exchange="directExchange"
routing-key="directRoutekey"
message-converter="mqMessageConvertor" />

<rabbit:listener-container connection-factory="mqConnectionFactory" message-converter="mqMessageConvertor">
<rabbit:listener ref="directListener" method="accept"
response-exchange="directExchange"
response-routing-key="directRoutekey"
queue-names="directQueue" />
</rabbit:listener-container>

DirectListener:

@Override
public void accept(String messageContent) throws Throwable {
log.info("direct listener");
}

2.fanout方式



<rabbit:fanout-exchange name="fanoutExchange"
auto-declare="true" auto-delete="false" durable="true" declared-by="mqAdmin">
rabbit:bindings
<rabbit:binding queue="fanoutQueue1"/>
<rabbit:binding queue="fanoutQueue2"/>
</rabbit:bindings>
</rabbit:fanout-exchange>
<rabbit:queue name="fanoutQueue1"
auto-declare="true" auto-delete="false"
durable="true" declared-by="mqAdmin" />
<rabbit:queue name="fanoutQueue2"
auto-declare="true" auto-delete="false"
durable="true" declared-by="mqAdmin" />

<rabbit:template id="fanout-template"
connection-factory="mqConnectionFactory"
queue="fanoutQueue"
exchange="fanoutExchange"
routing-key="fanoutRoutekey"
message-converter="mqMessageConvertor" />

<rabbit:listener-container connection-factory="mqConnectionFactory" message-converter="mqMessageConvertor">
<rabbit:listener ref="fanoutListener1" method="accept"
queue-names="fanoutQueue1" />
<rabbit:listener ref="fanoutListener2" method="accept"
queue-names="fanoutQueue2" />
</rabbit:listener-container>

FanoutListener1:

@Override
public void accept(String messageContent) throws Throwable {
log.info("fanout listener11111111111111");
}

FanoutListener2:

@Override
public void accept(String messageContent) throws Throwable {
log.info("fanout listener222222222222222");
}

运行代码,访问链接,查看结果。
访问/direct

[com.controller.IndexController]-[INFO] [rabbitmq][direct][start]
[com.service.IndexService]-[INFO] Message:DIRECT
[com.controller.IndexController]-[INFO] [rabbitmq][direct][end]
[com.listener.DirectListener]-[INFO] direct listener

访问/fanout

[com.controller.IndexController]-[INFO] [rabbitmq][fanout][start]
[com.service.IndexService]-[INFO] Message:FANOUT
[com.controller.IndexController]-[INFO] [rabbitmq][fanout][end]
[com.listener.FanoutListener2]-[INFO] fanout listener222222222222222
[com.listener.FanoutListener1]-[INFO] fanout listener11111111111111

posted @ 2017-10-13 18:04  CalronLoveRonnie  阅读(899)  评论(0)    收藏  举报
AmazingCounters.com