电商项目day13-1(jms入门)

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/wangwei_620/article/details/85163772

一.点对点模式

理解:

         点对点的模式主要建立在一个队列上面,当连接一个列队的时候,发送端不需要知道接收端是否正在接收,可以直接向 ActiveMQ 发送消息,发送的消息,将会先进入队列中,如果有接收端在监听,则会发向接收端,如果没有接收端接收,则会保存在 activemq 服务器,
直到接收端接收消息,点对点的消息模式可以有多个发送端,多个接收端,但是一条消息,只会被一个接收端给接收到,哪个接收端先连上 ActiveMQ,则会先接收到,而后来的接收端则接收不到那条消息。

1.创建工程

2.导入activemq-client 包

public class QueueProducer {
    public static void main(String[] args) throws JMSException {
        //1.创建连接工厂
        ConnectionFactory connectionFactory = new ActiveMQConnectionFactory("tcp://192.168.25.128:61616");
        //2.获取连接
        Connection connection = connectionFactory.createConnection();
        //3.启动连接
        connection.start();
        //4.获取session(参数一:是否启动事物  参数二:消息确认)
        Session session = connection.createSession(false, Session.AUTO_ACKNOWLEDGE);
        /*
            AUTO_ACKNOWLEDGE = 1 自动确认
             CLIENT_ACKNOWLEDGE = 2 客户端手动确认
             DUPS_OK_ACKNOWLEDGE = 3 自动批量确认
             SESSION_TRANSACTED = 0 事务提交并确认
         */
        //5.创建消息队列
        Queue queue = session.createQueue("test-queue");
        //6.创建消息生产者
        MessageProducer producer = session.createProducer(queue);
        //7.创建消息
        TextMessage textMessage = session.createTextMessage("欢迎来到ActiveMQ的世界");
        //8.发送消息
        producer.send(textMessage);
        //9.关闭资源
        producer.close();
        session.close();
        connection.close();
    }
}

创建消费者:

public class QueueConsumer {
    public static void main(String[] args) throws JMSException, IOException {
        //1.创建连接工厂
        ConnectionFactory connectionFactory = new ActiveMQConnectionFactory("tcp://192.168.25.128:61616");
        //2.获取连接
        Connection connection = connectionFactory.createConnection();
        //3.启动连接
        connection.start();
        //4.获取session(参数一:是否启动事物  参数二:消息确认)
        Session session = connection.createSession(false, Session.AUTO_ACKNOWLEDGE);
        /*
            AUTO_ACKNOWLEDGE = 1 自动确认
             CLIENT_ACKNOWLEDGE = 2 客户端手动确认
             DUPS_OK_ACKNOWLEDGE = 3 自动批量确认
             SESSION_TRANSACTED = 0 事务提交并确认
         */
        //5.创建消息队列
        Queue queue = session.createQueue("test-queue");
       //6.创建消费者
        MessageConsumer consumer = session.createConsumer(queue);
        //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.等待键盘输入
        System.in.read();
        //9.关闭资源
        consumer.close();
        session.close();
        connection.close();
    }
}

如果我们启动两个消费者,则只有一个消费者能输出消息

 

二.发布/订阅模式

public class TopicProducer {
    public static void main(String[] args) throws JMSException {
        //1.创建连接工厂
        ConnectionFactory connectionFactory = new ActiveMQConnectionFactory("tcp://192.168.25.128:61616");
        //2.获取连接
        Connection connection = connectionFactory.createConnection();
        //3.启动连接
        connection.start();
        //4.获取session(参数一:是否启动事物  参数二:消息确认)
        Session session = connection.createSession(false, Session.AUTO_ACKNOWLEDGE);
        /*
            AUTO_ACKNOWLEDGE = 1 自动确认
             CLIENT_ACKNOWLEDGE = 2 客户端手动确认
             DUPS_OK_ACKNOWLEDGE = 3 自动批量确认
             SESSION_TRANSACTED = 0 事务提交并确认
         */
        //5.创建主题对象
        Topic topic = session.createTopic("test-topic");
        //6.创建消息生产者
        MessageProducer producer = session.createProducer(topic);
        //7.创建消息
        TextMessage textMessage = session.createTextMessage("欢迎来到ActiveMQ的世界之topic");
        //8.发送消息
        producer.send(textMessage);
        //9.关闭资源
        producer.close();
        session.close();
        connection.close();
    }
}

创建消费者

public class TopicConsumer {
    public static void main(String[] args) throws JMSException, IOException {
        //1.创建连接工厂
        ConnectionFactory connectionFactory = new ActiveMQConnectionFactory("tcp://192.168.25.128:61616");
        //2.获取连接
        Connection connection = connectionFactory.createConnection();
        //3.启动连接
        connection.start();
        //4.获取session(参数一:是否启动事物  参数二:消息确认)
        Session session = connection.createSession(false, Session.AUTO_ACKNOWLEDGE);
        /*
            AUTO_ACKNOWLEDGE = 1 自动确认
             CLIENT_ACKNOWLEDGE = 2 客户端手动确认
             DUPS_OK_ACKNOWLEDGE = 3 自动批量确认
             SESSION_TRANSACTED = 0 事务提交并确认
         */
        //5.创建主题对象
        Topic topic = session.createTopic("test-topic");
        //6.创建消费者
        MessageConsumer consumer = session.createConsumer(topic);
        //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.一直保持监听状态
        while(true){}
        //9.关闭资源
        consumer.close();
        session.close();
        connection.close();
    }
}

当我们有两个消费者的时候,这个两个消费者都会有消息产生,这就是原生的发布/订阅模式

主要被监听的topic消息才能被消费

猜你喜欢

转载自blog.csdn.net/wangwei_620/article/details/85163772