ActiveMQ简单入门使用

参考学习慕课网教程记录笔记
https://www.imooc.com/learn/856

win 安装 activeMQ

下载安装包直接启动

http://activemq.apache.org/activemq-5153-release.html

启动最好右键以管理员身份启动

localhost:8161

这里写图片描述

这里写图片描述

队列模式的消息演示

创建工厂-》创建连接->会话->消费者,生产者,消息->目的地

pom

<dependencies>
<dependency>
<groupId>org.apache.activemq</groupId>
<artifactId>activemq-all</artifactId>
<version>5.9.0</version>
</dependency>
</dependencies>

队列生产者代码

package queue;

import org.apache.activemq.ActiveMQConnectionFactory;

import javax.jms.*;


/**
 * Created by Administrator on 2018/4/13.
 */
public class AppProducer {
/* 向消息中间件发送消息 */


    private static final String url     = "tcp://localhost:61616";
    private static final String queueName   = "queue-test";

    public static void main( String[] args ) throws JMSException
    {
/* 1.先创建连接工厂 */
        ConnectionFactory connectionFactory = new ActiveMQConnectionFactory( url );

/* 2.创建连接 */
        Connection connection = connectionFactory.createConnection();

/* 3.启动连接 */
        connection.start();

/* 4.创建会话 */
        Session session = connection.createSession( false, Session.AUTO_ACKNOWLEDGE );

/* 5.创建目的地 */
        Destination destination = session.createQueue( queueName );

/* 6.创建生产者 */
        MessageProducer producer = session.createProducer( destination );

        for ( int i = 0; i < 100; i++ )
        {
/* 7.创建消息 */
            TextMessage textMessage = session.createTextMessage( "test" + i );
/* 8.发布消息 */
            producer.send( textMessage );
            System.out.println( "发送消息 " + textMessage.getText() );
        }

/* 9.关闭连接 */
        connection.close();
    }
}

运行队列生产者代码 在 activeMQ中队列可以看到

这里写图片描述

此时还没消费者消费
建立消费者消费消息

package queue;

import org.apache.activemq.ActiveMQConnectionFactory;

import javax.jms.*;


/**
 * Created by Administrator on 2018/4/13.
 */
public class APPConsumer {
/* 队列消费者 */
    private static final String url     = "tcp://localhost:61616";
    private static final String queueName   = "queue-test";

    public static void main( String[] args ) throws JMSException
    {
/* 1.先创建连接工厂 */
        ConnectionFactory connectionFactory = new ActiveMQConnectionFactory( url );

/* 2.创建连接 */
        Connection connection = connectionFactory.createConnection();

/* 3.启动连接 */
        connection.start();

/* 4.创建会话 */
        Session session = connection.createSession( false, Session.AUTO_ACKNOWLEDGE );

/* 5.创建目的地 */
        Destination destination = session.createQueue( queueName );

/* 6.创建消费者 */
        MessageConsumer consumer = session.createConsumer( destination );

/* 7.创建监听器 */
        consumer.setMessageListener( new MessageListener()
                         {
                             public void onMessage( Message message )
                             {
/* 接收消息 */
                                 TextMessage textMessage = (TextMessage) message;
                                 try {
                                     System.out.println( "接收消息 " + textMessage.getText() );
                                 } catch ( JMSException e ) {
                                     e.printStackTrace();
                                 }
                             }
                         } );


/*
 * 8.关闭连接
 * connection.close();
 * 消息监听是异步的,要在程序退出后关闭
 */
    }
}

这里写图片描述

此时 ActiveMQ 消息没了,有一个监听者

这里写图片描述

如果一个生产者,两个监听者

生产者:发送100个

这里写图片描述

消费者 1
这里写图片描述

消费者 2
这里写图片描述

队列模式是将生产者生产的消费一半一半分给了两个消费者

主题模式的消息演示

代码与队列类似改几个地方就行

修改 创建会话后创建目标创建的是主题模式

一个生产者两个消费者

生产者:

这里写图片描述

消费者1

这里写图片描述

消费者2
这里写图片描述
主题模式的生产者的消息多个消费者接收到一样的消息,都接收一遍

Spring JMS

使用 Spring集成JMS连接ActiveMQ

ConnectionFactory 用于管理连接的连接工厂

一个 Spring为我们提供的连接池
JmsTemplate每次发消息都会重新创建连接,会话和 proudctor
spring中提供了SingleConnectionFactory和CachingConnectionFactory

JmsTemplate 用于发送和接收消息的模板类

是 spring 提供的,只需向 spring容器内注册这个类就可以使用 JmsTemplate

方便的操作 jms
JmsTemplate类是线程安全的,可以在整个应用范围使用

MessageListerner 消息监听器

实现一个 onMessage方法,该方法只接收一个Message参数

pom.xml

<?xml version="1.0" encoding="UTF-8"?>
<project
    xmlns="http://maven.apache.org/POM/4.0.0"
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation="http://maven.apache.org/POM/4.0.0http://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>
    <groupId>com.recar</groupId>
    <artifactId>jms-spring</artifactId>
    <version>1.0-SNAPSHOT</version>
    <dependencies>
        <dependency>
            <groupId>junit</groupId>
            <artifactId>junit</artifactId>
            <version>4.11</version>
            <scope>test</scope>
        </dependency>
        <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-context</artifactId>
            <version>4.2.5.RELEASE</version>
        </dependency>
        <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-jms</artifactId>
            <version>4.2.5.RELEASE</version>
        </dependency>
        <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-test</artifactId>
            <version>4.2.5.RELEASE</version>
        </dependency>
        <dependency>
            <groupId>org.apache.activemq</groupId>
            <artifactId>activemq-core</artifactId>
            <version>5.7.0</version>
            <exclusions>
                <exclusion>
                    <artifactId>spring-context</artifactId>
                    <groupId>org.springframework</groupId>
                </exclusion>
            </exclusions>
        </dependency>
    </dependencies>
</project>

spring对生产者的配置

producer.xml

<?xml version="1.0" encoding="UTF-8"?>
<beans
    xmlns="http://www.springframework.org/schema/beans"
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    xmlns:p="http://www.springframework.org/schema/p"
    xmlns:context="http://www.springframework.org/schema/context"
xsi:schemaLocation="http://www.springframework.org/schema/beanshttp://www.springframework.org/schema/beans/spring-beans.xsdhttp://www.springframework.org/schema/toolhttp://www.springframework.org/schema/tool/spring-tool.xsdhttp://www.springframework.org/schema/contexthttp://www.springframework.org/schema/context/spring-context.xsd">
    <!--引入使用注解-->
    <context:annotation-config></context:annotation-config>
    <!--ActiveMQ为我们提供的ConnectionFacroty-->
    <bean id="targetConnectionFactory" class="org.apache.activemq.ActiveMQConnectionFactory">
        <property name="brokerURL" value="tcp://localhost:61616"></property>
    </bean>
    <!--spring jms为我们提供连接池-->
    <bean id="connectionFactory" class="org.springframework.jms.connection.SingleConnectionFactory">
        <property name="targetConnectionFactory" ref="targetConnectionFactory"/>
    </bean>
    <!--创建一个队列目的地,点对点的-->
    <bean id="queueDestination" class="org.apache.activemq.command.ActiveMQQueue">
        <constructor-arg value="queue"></constructor-arg>
    </bean>
    <!--配置jmstemplate用于发送消息-->
    <bean id="jmsTemplate" class="org.springframework.jms.core.JmsTemplate">
        <property name="connectionFactory" ref="connectionFactory"></property>
    </bean>
    <!--生产者发送消息的实现类-->
    <bean class="jms.producer.ProducerServiceImpl"></bean>
</beans>

创建接口 Producer和实现类,并将实现来 写在配置文件中

实现类

package jms.producer;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.jms.core.JmsTemplate;
import org.springframework.jms.core.MessageCreator;
import javax.annotation.Resource;
import javax.jms.*;
/*** Created by Administrator on 2018/4/13.*/
public class ProducerServiceImpl implements ProducerService{
    @AutowiredJmsTemplate jmsTemplate;
    //以资源的方式注入,因为 有可能多个目的地
    @Resource(name="queueDestination")
    Destination destination;
    public void sendMessage(final String message) {
        jmsTemplate.send(destination, new MessageCreator() {
            public Message createMessage(Session session) throws JMSException { 
                TextMessage textMessage = session.createTextMessage(message);
                System.out.println("发送消息 "+textMessage.getText());return textMessage;
  }}) ;
}}

创建调用生产者的类

package jms.producer;

import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;


/**
 * Created by Administrator on 2018/4/13.
 */
public class AppProducer {
/* 启动生产者发送消息 */
    public static void main( String[] args )
    {
        ApplicationContext context = new ClassPathXmlApplicationContext( "producer.xml" );

        ProducerService service = context.getBean( ProducerService.class );

        for ( int i = 0; i < 100; i++ )
        {
            service.sendMessage( "test " + i );
        }
    }
}

运行发送成功

这里写图片描述

实现关闭连接

((ClassPathXmlApplicationContext)context).close();

不然一直有

这里写图片描述

创建消费者

配置
consumer.xml

<?xml version="1.0" encoding="UTF-8"?>
<beans
    xmlns="http://www.springframework.org/schema/beans"
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    xmlns:p="http://www.springframework.org/schema/p"
    xmlns:context="http://www.springframework.org/schema/context"
xsi:schemaLocation="http://www.springframework.org/schema/beanshttp://www.springframework.org/schema/beans/spring-beans.xsdhttp://www.springframework.org/schema/toolhttp://www.springframework.org/schema/tool/spring-tool.xsdhttp://www.springframework.org/schema/contexthttp://www.springframework.org/schema/context/spring-context.xsd">
    <!--引入使用注解-->
    <context:annotation-config></context:annotation-config>
    <!--ActiveMQ为我们提供的ConnectionFacroty-->
    <bean id="targetConnectionFactory" class="org.apache.activemq.ActiveMQConnectionFactory">
        <property name="brokerURL" value="tcp://localhost:61616"></property>
    </bean>
    <!--spring jms为我们提供连接池-->
    <bean id="connectionFactory" class="org.springframework.jms.connection.SingleConnectionFactory">
        <property name="targetConnectionFactory" ref="targetConnectionFactory"/>
    </bean>
    <!--创建一个队列目的地,点对点的-->
    <bean id="queueDestination" class="org.apache.activemq.command.ActiveMQQueue">
        <constructor-arg value="queue"></constructor-arg>
    </bean>
    <!--配置消息监听器-->
    <bean id="consumberMessageListener" class="consumer.ConsumerMessageListener"></bean>
    <!--配置消息监听容器-->
    <bean id="jmsContainer" class="org.springframework.jms.listener.DefaultMessageListenerContainer">
        <property name="connectionFactory" ref="connectionFactory"></property>
        <property name="destination" ref="queueDestination"></property>
        <property name="messageListener" ref="consumberMessageListener"></property>
    </bean>
</beans>

创建监听器

要实现接口 MessageListener

package consumer;

import javax.jms.JMSException;
import javax.jms.Message;
import javax.jms.MessageListener;
import javax.jms.TextMessage;


/**
 * Created by Administrator on 2018/4/13.
 */
public class ConsumerMessageListener implements MessageListener {
    public void onMessage( Message message )
    {
        TextMessage textMessage = (TextMessage) message;
        try {
            System.out.println( "接受消息 " + textMessage.getText() );
        } catch ( JMSException e ) {
            e.printStackTrace();
        }
    }
}

调用

package consumer;

import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;


/**
 * Created by Administrator on 2018/4/13.
 */
public class AppConsumer {
    public static void main( String[] args )
    {
        ApplicationContext context = new ClassPathXmlApplicationContext( "consumer.xml" );
    }
}

直接启动就可以接收消息

接收消息
这里写图片描述

主题模式

配置文件增加 主题模式目的地

<!--主题目的地,发布订阅模式-->
<bean id="topicDestination" class="org.apache.activemq.command.ActiveMQTopic">
<constructor-arg value="topic"></constructor-arg>
</bean>

然后在生产者的目的地注入修改

//以资源的方式注入,因为 有可能多个目的地
@Resource(name="topicDestination")
Destination destination;

在消息监听器容器修改(消费者配置文件)

<!--配置消息监听容器-->
<bean id="jmsContainer" class="org.springframework.jms.listener.DefaultMessageListenerContainer">
<property name="connectionFactory" ref="connectionFactory"></property>
<property name="destination" ref="topicDestination"></property>
<property name="messageListener" ref="consumberMessageListener"></property>
</bean>

就将队列修改为主题模式

启动两个订阅者也就是消费者,一个生产者

生产者
这里写图片描述

订阅者1

这里写图片描述

订阅者2
这里写图片描述

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要开始使用ActiveMQ,您需要按照以下步骤进行安装和配置: 1. 首先,您可以从ActiveMQ的官方网站()下载安装包。您可以在此链接中找到最新的版本。 2. 下载完成后,您可以使用wget命令()将下载的安装包传输到您的Linux系统中。 3. 解压缩安装包,您可以使用tar命令()执行:tar -xzvf apache-activemq-5.14.0-bin.tar.gz。这将解压缩安装包到当前目录。 4. 进入解压缩后的bin目录,并启动ActiveMQ。您可以使用命令:./activemq start。这将启动ActiveMQ,并将其作为后台进程运行。 5. 您可以使用命令ps -ef|grep activemq检查ActiveMQ是否成功启动()。 一旦ActiveMQ成功安装并启动,您可以使用Java代码与其进行交互。以下是一些基本操作: 1. 导入ActiveMQ的依赖项。您可以在您的Java项目的pom.xml文件中添加以下依赖项(): <dependency> <groupId>org.apache.activemq</groupId> <artifactId>activemq-all</artifactId> <version>5.15.9</version> </dependency> 2. 创建队列。您可以使用ActiveMQ的API来创建一个队列,以便在消息传递中使用。 3. 创建主题。类似于队列,您也可以使用ActiveMQ的API来创建一个主题,用于发布和订阅消息。 这些是使用ActiveMQ的一些基本入门步骤。您可以通过阅读ActiveMQ的官方文档和API文档来深入了解更多功能和使用方法。希望这可以帮助您开始使用ActiveMQ。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* [ActiveMQ入门](https://blog.csdn.net/qq_34195507/article/details/101022427)[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: 50%"] - *3* [ActiveMQ入门学习](https://blog.csdn.net/dpf373521/article/details/101024790)[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: 50%"] [ .reference_list ]

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值