有这样的一个业务场景,生产者发送消息后,一个以点对点的模式接收,一个已发布订阅的模式接收。当然我们可以做,生产者发送两个Destination,一个是点对点模式,一个是发布订阅模式。这样比较麻烦,activemq也提供了他的方法来处理这样的场景:

示例

生产者的主要代码如下:

session.createQueue("test.ptp,topic://test.topic");

整体代码:

public static void main(String[] args) {
        ConnectionFactory connectionFactory;
        Connection connection = null;
        Session session = null;
        Destination destination;
        MessageProducer producer = null;
        Message message;
        boolean useTransaction = false;
        try {
            // 创建一个ConnectionFactory
            connectionFactory = new ActiveMQConnectionFactory();
            // 创建一个Connection
            connection = connectionFactory.createConnection();
            // 启动消息传递的连接
            connection.start();
            // 创建一个session
            session = connection.createSession(useTransaction, Session.AUTO_ACKNOWLEDGE);
            // 创建一个destination,把消息发送到test.queue
            destination = session.createQueue("test.ptp,topic://test.topic");
            // 创建一个生产者
            producer = session.createProducer(destination);
            // 创建一个消息
            message = session.createTextMessage("this is test.multipledesc");
            // 发送消息
            producer.send(message);
        } catch (JMSException e) {
            e.printStackTrace();
        } finally {
            try {
                if (producer != null) {
                    producer.close();
                }
                if (session != null) {
                    session.close();
                }
                if (connection != null) {
                    connection.close();
                }
            } catch (JMSException e) {
                e.printStackTrace();
            }
        }
    }

消费者1,点对点模式参考之前的点对点
消费者2、消费者3,发布订阅模式,同之前的发布订阅
运行消费者3个客户端,再运行生产者,可以看到消息的接收处理。


大军
847 声望183 粉丝

学而不思则罔,思而不学则殆


引用和评论

0 条评论