189 8069 5689

如何解析SpringBoot整合ActiveMQ过程

如何解析SpringBoot整合ActiveMQ过程,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。

创新互联专注于莱芜网站建设服务及定制,我们拥有丰富的企业做网站经验。 热诚为您提供莱芜营销型网站建设,莱芜网站制作、莱芜网页设计、莱芜网站官网定制、小程序设计服务,打造莱芜网络公司原创品牌,更为您提供莱芜网站排名全网营销落地服务。

目录结构

引入 maven依赖

   org.springframework.boot    spring-boot-starter-parent    1.5.4.RELEASE            UTF-8    UTF-8    1.8              org.springframework.boot      spring-boot-starter              org.springframework.boot      spring-boot-starter-web              org.springframework.boot      spring-boot-starter-test      test              org.springframework.boot      spring-boot-starter-activemq                          org.springframework.boot        spring-boot-maven-plugin            

引入 application.yml配置

spring: activemq:  broker-url: tcp://127.0.0.1:61616  user: admin  password: adminqueue: springboot-queueserver: port: 8080

创建QueueConfig

@Configurationpublic class QueueConfig {  @Value("${queue}")  private String queue;  @Bean  public Queue logQueue() {    return new ActiveMQQueue(queue);  }  @Bean  public JmsTemplate jmsTemplate(ActiveMQConnectionFactory activeMQConnectionFactory, Queue queue) {    JmsTemplate jmsTemplate = new JmsTemplate();    jmsTemplate.setDeliveryMode(2);// 进行持久化配置 1表示非持久化,2表示持久化    jmsTemplate.setConnectionFactory(activeMQConnectionFactory);    jmsTemplate.setDefaultDestination(queue); // 此处可不设置默认,在发送消息时也可设置队列    jmsTemplate.setSessionAcknowledgeMode(4);// 客户端签收模式    return jmsTemplate;  }  // 定义一个消息监听器连接工厂,这里定义的是点对点模式的监听器连接工厂  @Bean(name = "jmsQueueListener")  public DefaultJmsListenerContainerFactory jmsQueueListenerContainerFactory(      ActiveMQConnectionFactory activeMQConnectionFactory) {    DefaultJmsListenerContainerFactory factory = new DefaultJmsListenerContainerFactory();    factory.setConnectionFactory(activeMQConnectionFactory);    // 设置连接数    factory.setConcurrency("1-10");    // 重连间隔时间    factory.setRecoveryInterval(1000L);    factory.setSessionAcknowledgeMode(4);    return factory;  }}

创建生产者:

@SpringBootApplication@Component@EnableSchedulingpublic class Producer {    @Autowired  private JmsMessagingTemplate jmsMessagingTemplate;    @Autowired  private Queue queue;    @Scheduled(fixedDelay=3000)  public void send() {    String result = System.currentTimeMillis()+"---测试";    System.out.println("result"+result);    jmsMessagingTemplate.convertAndSend(queue,result);  }  public static void main(String[] args) {    SpringApplication.run(Producer.class, args);  }}

创建消费者的application.yml

spring: activemq:  broker-url: tcp://127.0.0.1:61616  user: admin  password: adminqueue: springboot-queueserver: port: 8081

创建消费者:

@Component@SpringBootApplicationpublic class consumer {  private int count =0;    @JmsListener(destination = "${queue}")  public void receive(TextMessage textMessage,Session session) throws JMSException {    String text = textMessage.getText();        System.out.println("消费:"+text+"第几次获取消息count:"+(++count));        System.out.println();    String jmsMessageID = textMessage.getJMSMessageID();  }   public static void main(String[] args) {    SpringApplication.run(consumer.class,args);  }}

看完上述内容是否对您有帮助呢?如果还想对相关知识有进一步的了解或阅读更多相关文章,请关注创新互联行业资讯频道,感谢您对创新互联的支持。


网站标题:如何解析SpringBoot整合ActiveMQ过程
网页链接:http://gzruizhi.cn/article/ipjesc.html

其他资讯