springboot与activemq

本文章简单介绍了activemq,以及在springboot项目中使用activemq

activemq介绍

ActiveMQ 是Apache出品,最流行的,能力强劲的开源消息总线。
  ActiveMQ的消息机制:
    1.点对点方式:
  每个消息只能有一个消费者。
    2.发布/订阅消息传递域
      每个消息可以有多个消费者。

在springboot中使用

配置pom文件

<!-- activemq -->
<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-activemq</artifactId>
</dependency>

配置文件

spring:
    activemq:
       broker-url: tcp://localhost:61616 # URL of the ActiveMQ broker.Auto-generated by default. For instance `tcp://localhost:61616`
       in-memory: false # Specify if the default broker URL shouldbe in memory. Ignored if an explicit broker has been specified.是否是内存模式
       password: x  # Login password of the broker.
       user: xx  # Login user of the broker.
       packages:
         trust-all: false
         trusted: com.hfy.activemq # Trust all packages.
       pool:
         enabled: false

配置工厂

import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.jms.annotation.EnableJms;
import org.springframework.jms.config.DefaultJmsListenerContainerFactory;
import org.springframework.jms.config.JmsListenerContainerFactory;

import javax.jms.ConnectionFactory;

@Configuration
@EnableJms
public class JmsConfiguration {

    // queue模式的ListenerContainer
    @Bean(name = "jmsListenerContainerQueue")
    public JmsListenerContainerFactory<?> jmsListenerContainerQueue(ConnectionFactory activeMQConnectionFactory) {
        DefaultJmsListenerContainerFactory bean = new DefaultJmsListenerContainerFactory();
        // 实际运行时DefaultMessageListenerContainer对象将使用5000ms(5s)这个时间间隔刷新JMS连接,输出连接异常信息
        // 此处使用10s重连
        bean.setRecoveryInterval(10000L);
        bean.setConnectionFactory(activeMQConnectionFactory);
        return bean;
    }

    // topic模式的ListenerContainer
    @Bean(name = "jmsListenerContainerTopic")
    public JmsListenerContainerFactory<?> jmsListenerContainerTopic(ConnectionFactory activeMQConnectionFactory) {
        DefaultJmsListenerContainerFactory bean = new DefaultJmsListenerContainerFactory();
        // 实际运行时DefaultMessageListenerContainer对象将使用5000ms(5s)这个时间间隔刷新JMS连接,输出连接异常信息
        // 此处使用10s重连
        bean.setRecoveryInterval(10000L);
        bean.setPubSubDomain(true);
        bean.setConnectionFactory(activeMQConnectionFactory);
        return bean;
    }
}

发送消息

import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.jms.core.JmsTemplate;
import org.springframework.stereotype.Service;

@Service
public class SendMsgServiceImpl implements SendMsgService {

    private static final Logger logger = LoggerFactory.getLogger(SendMsgServiceImpl.class);

    @Autowired
    private JmsTemplate jmsTemplate;

    @Override
    public void sendQueueMessageText(String message) {
        logger.info("activemq发送消息:{}", message);
        jmsTemplate.convertAndSend(QueueList.QUEUE_SEND, message);
    }
}

接收消息

此处是接收的topic模式的消息

import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.jms.annotation.JmsListener;
import org.springframework.stereotype.Service;

@Service
public class ReceiveMsgServiceImpl implements ReceiveMsgService {

    private static final Logger logger = LoggerFactory.getLogger(ReceiveMsgServiceImpl.class);

    @JmsListener(destination = QueueList.TOPIC_RECEIVE, containerFactory = "jmsListenerContainerTopic")
    @Override
    public void getQueueMessageText(String message) {
        try {
            logger.info("activemq收到消息:{}", message);
            // ...
        } catch (IOException e) {
            // ...
        }

    }

}

队列的定义

import org.apache.activemq.command.ActiveMQQueue;
import org.springframework.context.annotation.Bean;
import org.springframework.stereotype.Component;

/**
 * 消息队列
 */
@Component
public class QueueList {

    public static final String QUEUE_SEND = "queue_send";
    public static final String TOPIC_RECEIVE = "topic_receive";
}

异常错误

Could not connect to broker URL

问题:
  Could not refresh JMS Connection for destination ‘queue_toc_tob’ - retrying using FixedBackOff{interval=10000, currentAttempts=2013, maxAttempts=unlimited}. Cause: Could not connect to broker URL: tcp://localhost:61616. Reason: java.net.ConnectException: Connection refused
分析:
  activemq正常启动着,数据量小没有问题,通过 nestat -nalp |grep 61616 发现有很多连接。
解决:
  使用连接池。
1、在pom.xml中:(springboot使用1.5.6.RELEASE版本)

    <!-- activemq support -->
		<dependency>
			<groupId>org.springframework.boot</groupId>
			<artifactId>spring-boot-starter-activemq</artifactId>
		</dependency>
		<dependency>
			<groupId>org.apache.activemq</groupId>
			<artifactId>activemq-pool</artifactId>
		</dependency>

2、在application.yml中:

spring:
    activemq:
       。。。。。。
       pool:
         enabled: true
         max-connections: 2
         expiry-timeout: 10000
         idle-timeout: 30000

参考

http://blog.csdn.net/q_zx1bydcom/article/details/53078870

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要配置Spring Boot整合ActiveMQ,你可以按照以下步骤进行操作: 1. 添加ActiveMQ依赖: 在你的项目中的pom.xml文件中,添加以下依赖项: ``` <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-activemq</artifactId> </dependency> ``` 2. 配置ActiveMQ连接信息: 在你的application.properties或application.yml文件中,添加以下配置: ``` spring.activemq.broker-url=tcp://localhost:61616 spring.activemq.user=admin spring.activemq.password=admin ``` 这里,你需要设置ActiveMQ的通信地址,以及账户名和密码。 3. 配置队列或主题模式: 默认情况下,ActiveMQ提供的是队列模式。如果你想使用主题模式,可以添加以下配置: ``` spring.jms.pub-sub-domain=true ``` 4. 启动ActiveMQ服务器: 你需要启动ActiveMQ服务器来进行消息的发送和接收。可以通过在浏览器中访问http://localhost:8161,使用管理员账户名和密码(admin/admin)登录ActiveMQ管理界面来启动服务器。 这样,你就可以在Spring Boot项目中成功配置和使用ActiveMQ了。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [java springboot整合activemq工程](https://download.csdn.net/download/weixin_47315082/88136003)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 33.333333333333336%"] - *2* [Springboot整合ActiveMQ](https://blog.csdn.net/weixin_45698637/article/details/123443728)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 33.333333333333336%"] - *3* [《SpringBoot篇》25.SpringBoot整合ActiveMQ](https://blog.csdn.net/weixin_47343544/article/details/128164353)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 33.333333333333336%"] [ .reference_list ]

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值