基于JMS的ActiveMQ搭建与实现

1.JMS

  Java消息服务(Java Message Service)即JMS,是一个Java平台中关于面向消息中间件的API,用于两个程序之间,或分布式系统中发送消息,进行异步通信。

  JMS包括队列与主题两种模式,一种是点对点的Queue,还有一个是发布订阅的Topic方式。区别在于:
  (1)对于Queue模式,一个发布者发布消息,下面的接收者按队列顺序接收,比如发布了10个消息,两个接收者A,B那就是A,B总共会收到10条消息,不重复。
  (2)对于Topic模式,一个发布者发布消息,有两个接收者A,B来订阅,那么发布了10条消息,A,B各收到10条消息。

2.消息中间件

  消息中间件有很多的用途和优点:
  (1) 将数据从一个应用程序传送到另一个应用程序,或者从软件的一个模块传送到另外一个模块;
  (2)负责建立网络通信的通道,进行数据的可靠传送;
  (3)保证数据不重发,不丢失 ;
  (4)能够实现跨平台操作,能够为不同操作系统上的软件集成技工数据传送服务。

3.ActiveMQ

  ActiveMQ 是Apache出品,最流行的,能力强劲的开源消息总线。ActiveMQ 是一个完全支持JMS1.1和J2EE 1.4规范的 JMS Provider实现,尽管JMS规范出台已经是很久的事情了,但是JMS在当今的J2EE应用中间仍然扮演着特殊的地位。

4.ActiveMQ安装

  (1)官方网址:http://activemq.apache.org/,下载对应的程序,如下图所示。

  

  (2)解压到本地,在apache-activemq-5.15.0\bin\win64的目录下选择InstallService.bat启动服务,这样下次只要到系统服务里去启动与关闭,如下图所示。

  

  (3)至此,activemq的服务已经启动。

5.Demo项目结构

6.代码实现生产者消费者模式

  (1)配置依赖项

    在pom.xml里添加依赖jar包

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

  (2)实现生产者(队列模式)

package com.snail.queue;
import org.apache.activemq.ActiveMQConnectionFactory;
import javax.jms.*;

/**
 * 生产者(队列模式)
 * Create by zhangviv
 * 2017-08-25 14:06
 **/
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 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);
            producer.send(textMessage);
            System.out.println("发送消息:" + textMessage.getText());
        }

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

  (3)实现消费者(队列模式)

package com.snail.queue;
import org.apache.activemq.ActiveMQConnectionFactory;
import javax.jms.*;

/**
 *  消费者(队列模式)
 * Create by zhangviv
 * 2017-08-25 14:12
 **/
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 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();
                }
            }
        });

    }
}

  (4)ActiveMQ客户端查看队列模式

  

  (5)实现生产者(主题模式)

package com.snail.topic;
import org.apache.activemq.ActiveMQConnectionFactory;
import javax.jms.*;


/**
 * 生产者(主题模式)
 * Create by zhangviv
 * 2017-08-25 14:06
 **/
public class TopicProducer {
    private static final String url = "tcp://localhost:61616";
    private static final String topicName = "topic-test";

    public static void main(String[] args) throws JMSException {
        //1.创建ConnectionFactory
        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.createTopic(topicName);

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

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

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

  (6)实现消费者模式(主题模式)

package com.snail.topic;
import org.apache.activemq.ActiveMQConnectionFactory;
import javax.jms.*;

/**
 *  消费者(主题模式)
 * Create by zhangviv
 * 2017-08-25 14:12
 **/
public class TopicConsumer {
    private static final String url="tcp://localhost:61616";
    private  static final String topicName="topic-test";
    public static void main(String[] args) throws JMSException {
        //1.创建ConnectionFactory
        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.createTopic(topicName);

        //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();
                }
            }
        });
        
    }
}

  (7)ActiveMQ客户端查看主题模式

  

 

posted @ 2017-08-28 10:21  TechSnail  阅读(824)  评论(0编辑  收藏  举报