ActiveMq 基础实战

开始实战之前,我们先来看一下JMS的基础 知识:
消息中间件初识

然后进入敲代码阶段:

队列模式:

首先我们来创建一个队列模式的ActiveMq。
AppProducer的代码如下:

package com.martina.jms.test1;

import org.apache.activemq.ActiveMQConnectionFactory;

import javax.jms.*;

public class AppProducer {
    private static final String url="tcp://127.0.0.1:61616";
    private static  final String queueName="queue-test";

    public static void main(String[] args) throws JMSException {
        //创建ConnectionFactory

        ConnectionFactory connectionFactory=new ActiveMQConnectionFactory(url);

        //创建Connection
        Connection connection=connectionFactory.createConnection();

        //启动连接
        connection.start();
        //创建会话
         /* 在connection创建session的时候,第一个参数决定session事物是否开启,true时session事物开启。为false时 ,session事物关闭。
        Session.AUTO-ACKNOWLEDGE,session负责发送过去消息,收到自动确认。
        Session.CLIENT-ACKNOWLEDGE(接收端确认接收到这条消息,调用这条消息的确认方法)。
        session.DUPS_OK_ACKNOWLEDGE(懒散的确认方法,这种确认方法有可能传递的一些复制信息会出错)。 
        */
        Session session=connection.createSession(false,Session.AUTO_ACKNOWLEDGE);
        //创建一个目标

        Destination destination=session.createQueue(queueName);

        //创建一个生产者,然后创建并发送消息
        MessageProducer producer=session.createProducer(destination);

        for(int i=0;i<20;i++){
            TextMessage textMessage=session.createTextMessage("test");
            // TextMessage textMessage=session.createTextMessage("test"+i);
            producer.send(textMessage);
            System.out.println("发送消息"+textMessage.getText());
        }

        //最后关闭连接
        connection.close();

    }
}

然后执行AppProducer之后,可以看到
在这里插入图片描述在这里插入图片描述
然后我们创建一个AppConsumer类,代码如下:

package com.martina.jms.testQueue;

import org.apache.activemq.ActiveMQConnectionFactory;

import javax.jms.*;

public class AppConsumer {
    private static final String url="tcp://127.0.0.1:61616";
    private static  final String queueName="queue-test";

    public static void main(String[] args) throws JMSException {
        //创建ConnectionFactory

        ConnectionFactory connectionFactory=new ActiveMQConnectionFactory(url);

        //创建Connection
        Connection connection=connectionFactory.createConnection();

        //启动连接
        connection.start();
        //创建会话
         /* 在connection创建session的时候,第一个参数决定session事物是否开启,true时session事物开启。为false时 ,session事物关闭。
        Session.AUTO-ACKNOWLEDGE,session负责发送过去消息,收到自动确认。
        Session.CLIENT-ACKNOWLEDGE(接收端确认接收到这条消息,调用这条消息的确认方法)。
        session.DUPS_OK_ACKNOWLEDGE(懒散的确认方法,这种确认方法有可能传递的一些复制信息会出错)。 
        */
        Session session=connection.createSession(false,Session.AUTO_ACKNOWLEDGE);
        //创建一个目标

        Destination destination=session.createQueue(queueName);

        //创建一个消费者
        final MessageConsumer consumer=session.createConsumer(destination);

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


        //最后关闭连接
        //注意这里:当开始时候就直接关闭的话,上面的消息就不会输出,所以要注释掉这一行
     //   connection.close();

    }
}

然后我们执行一个Consumer,就会接收到我们之前Producer发送的20条消息,再执行新的Consumer时,就不会有接收到任何消息。
然后我们清空所有之后,先执行起两个Consumer,然后执行一个Producer,就会发现两个Consumer的控制台输出情况如下:也就是两个consumer均分所有的Producer产生的消息。
在这里插入图片描述
在这里插入图片描述

主题模式:

主题模式的创建和队列模式的创建相差无几:主要是修改以下内容:
在这里插入图片描述
在这里插入图片描述

运行AppProducer程序之后,我们直接查看ActiveMq的官网:找到对应的Topics:
在这里插入图片描述
就会找到我们自己创建的Topics,以及发送的消息数量。
在这里插入图片描述
这时候运行Topic下的APPConsumer,就会发现没有接收到任何消息。因为在 主题模式下,只有消费者提前订阅了主题,才可以接收到消息发送者的消息。
那么我们可以重新执行AppProducer(保持AppConsumer开启),那么就会发现consumer中接收到了消息。

好的,接下来我们来证明主题模式下,两个应用(消费者)都会收到所有的producer发送的消息。
开启两个消费者,clear All 控制台,重新执行Producer,查看两个Consumer控制台,就会发现两个Consumer接收消息情况如下:
在这里插入图片描述
在这里插入图片描述

也就是证明了两个不同方式的(队列和主题模式)区别:队列是平均分Producer发送的消息,主题是接收所有的消息。

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值