淺談Spring Boot 整合ActiveMQ的過程
RabbitMQ是比較常用的AMQP實現,這篇文章是一個簡單的Spring boot整合RabbitMQ的教程。
安裝ActiveMQ服務器,(也可以不安裝,如果不安裝,會使用內存mq)
構建Spring boot項目,增加依賴項,只需要添加這一項即可
<!-- 添加acitivemq依賴 --> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-activemq</artifactId> </dependency>
增加Application類
@SpringBootApplication
@EnableScheduling //使用定時任務發(fā)送消息
public class MqTestApplication {
public static void main(String[] args) {
SpringApplication.run(MqTestApplication.class, args);
}
}
配置application.yml
spring: activemq: broker-url: tcp://127.0.01:61616 packages: trust-all: true
構建一個數據Model,可以發(fā)送和消費的數據類型有: String, byte array, Map<String,?>, Serializable object.
// 如果發(fā)送的消息是一個對象,必須implements Serializable接口
public class TModel implements Serializable {
private static final long serialVersionUID = -921008687184331557L;
private int count;
public TModel(int count) {
this.count = count;
}
@Override
public String toString() {
return "TModel [count=" + count + "]";
}
}
構建Producer
@Component
public class Producer {
// 在Producer中注入JmsTemplate,我們可以通過這個template發(fā)送消息
private final JmsTemplate jmsTemplate;
private int count = 0;
@Autowired
public Producer(JmsTemplate jmsTemplate) {
this.jmsTemplate = jmsTemplate;
}
// 這里使用Spring Boot的定時任務發(fā)送消息
@Scheduled(fixedRate = 1000)
public void create() {
// 使用convertAndSend發(fā)送消息
jmsTemplate.convertAndSend("queue1", new TModel(count++));
}
}
構建Consumer
@Component
public class Consumer {
@JmsListener(destination = "queue1")
public void comsume(TModel content) {
System.out.println("recive message from queue1 [" + content + "]");
}
}
特別備注:如果我們的生產者和消費者在不同的Module中時,最好將要消費的數據抽象成公共Module.程序是通過Serializable來序列化和反序列化對象的。必須保證生產者和消費者的對象模型的serialVersionUID是一致的。
項目地址: https://github.com/ldwqh0/active-mq-spring.git
示例:配置rabbitmq ,增加一個隊列
@Configuration
public class Aqueue {
@Bean
public Queue queue() {
return new Queue("good");
}
}
定義一個生產者.
當啟用activemq之后,會自動創(chuàng)建一個AmqpTemplate ,可以被注入到任何需要的地方,我們可以通過這個AmqpTemplate發(fā)送消息到MQ中
/**
* 定義一個生產者
* @author LiDong
*/
@RestController
@RequestMapping("/test")
public class SendController {
@Autowired
private AmqpTemplate template;
@GetMapping
public String testSend() {
// 使用AmqpTemplate發(fā)送消息
template.convertAndSend("good", "good");
return "success";
}
}
定義消費者,通過指定RabbitListener(queues='good')指定消費的隊列
@Component
public class Consumer {
/**
* 定義一個消費者
* @param message
*/
@RabbitListener(queues = "good")
public void handler(String message) {
System.out.println("recive message from " + message);
}
}
啟動測試,在瀏覽器中輸入 http://localhost:8080/test 即可發(fā)送一條消息到隊列中。 該對列可以被消費者處理
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關文章
springboot對接支付寶支付接口(詳細開發(fā)步驟總結)
這篇文章主要介紹了springboot對接支付寶支付接口(詳細開發(fā)步驟總結),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2020-06-06
關于Spring自定義XML schema 擴展的問題(Spring面試高頻題)
今天給大家分享一道spring高頻率面試題關于Spring自定義XML schema 擴展的問題,今天以spring整合dubbo的實例給大家詳細講解下,感興趣的朋友跟隨小編一起看看吧2021-05-05
hibernate 中 fetch=FetchType.LAZY 懶加載失敗處理方法
這篇文章主要介紹了hibernate 中 fetch=FetchType.LAZY 懶加載失敗處理方法,需要的朋友可以參考下2017-09-09
JDBC中Statement和Preparement的使用講解
今天小編就為大家分享一篇關于JDBC中Statement和Preparement的使用講解,小編覺得內容挺不錯的,現在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧2019-01-01

