MQ是一个消费者-生产者模型,可以将无需即使返回的操作提取出来,异步处理。在高并发的环境下sql来不及处理,请求会发生阻塞,通过MQ可以缓解压力。
可以用JMS(Java Message Service)兼容MQ,如ActiveMq就是支持JMS的开源MQ。
消息中间件的组成:
Broker:消息服务器,作为server提供消息核心服务
Producer:消息生产者
Consumer:消息消费者
Topic:主题, 发布/订阅下的消息统一汇集地 , 实现1vN
Queue:队列, PTP模式下, 生-Queue-订, 实现负载均衡
activemq主页:
localhost:8161/admin/
admin / admin
broker 一般是61616端口
主要应用:
1.异步处理
2.应用解耦
3.流量削峰
4.消息通讯(聊天室)
简单代码:
1.定时器
@Component
@EnableScheduling
public class PromoteActProducer {
@Autowired
private JmsMessagingTemplate jmsMessagingTemplate;
@Autowired
private Producer producer;
@Autowired
private Queue queue;
@Scheduled(fixedDelay = 2000) // 每2s执行1次
public void send() {
Destination destination = new ActiveMQQueue(“mytest.queue”);
for(int i=0; i<3; i++){
producer.sendMessage(destination, “myname is HjwJames!!!”);
}
}
}
2.消费者
@Component
public class Consumer {
@JmsListener(destination = “mytest.queue”)
@SendTo(“out2.queue”)
public String receiveQueue2(String text) {
System.out.println(“Consumer2收到的报文为:”+text);
return “return message”+text;
}
// 使用JmsListener配置消费者监听的队列,其中text是接收到的消息
@JmsListener(destination = “mytest.queue”)
@SendTo(“out.queue”)
public String receiveQueue(String text) {
System.out.println(“Consumer收到的报文为:”+text);
return “return message”+text;
}
}
3.生产者
@Service(“producer”)
public class Producer {
@Autowired // 也可以注入JmsTemplate,JmsMessagingTemplate对JmsTemplate进行了封装
private JmsMessagingTemplate jmsTemplate;
// 发送消息,destination是发送到的队列,message是待发送的消息
public void sendMessage(Destination destination, final String message){
jmsTemplate.convertAndSend(destination, message);
}
}