ActiveMQ消息处理机制-Topic方式

ActiveMQ的Topic方式允许一个消息有多个订阅者。消费者必须先订阅并保持运行状态才能接收消息。生产者通过session.createTopic创建Topic,而消费者可以定义多个监听器来接收消息,例如Listener1和Listener2。在实际运行中,两个消费者都能接收到发送的10条数据,体现了Topic的广播特性。
摘要由CSDN通过智能技术生成

特点: Topic方式每个消息都可以有多个订阅者(消费者),只要消费者订阅了这个主题(Topic),就可以获得这个消息。发布者和订阅者之间有时间上的依赖性。针对某个主题(Topic)的订阅者,它必须创建一个订阅者之后,才能消费发布者的消息,而且为了消费消息,订阅者必须保持运行的状态(也就是说在必须先启动消费者那方)。
所以在代码中得先启动消费者的服务,再发送消息
1.生产者
只需要改动queue方式中的代码destination=session.createQueue(“FirstQueue1”); // 创建消息队列
改为创建Topic就可以了。destination=session.createTopic(“FirstTopic1”);//创建topic

import javax.jms.Connection;
import javax.jms.ConnectionFactory;
import javax.jms.Destination;
import javax.jms.JMSException;
import javax.jms.MessageProducer;
import javax.jms.Session;
import javax.jms.TextMessage;
import org.apache.activemq.ActiveMQConnection;
import org.apache.activemq.ActiveMQConnectionFactory;
/**
 * 消息生产者-消息发布者
 * Topic 方式
 *
 */
public class JMSProducer {
   

    private static final String USERNAME=ActiveMQConnection.DEFAULT_USER; // 默认的连接用户名
    private static final String PASSWORD=ActiveMQConnection.DEFAULT_PASSWORD; // 默认的连接密码
    private static final String BROKEURL=ActiveMQConnection.DEFAULT_BROKER_URL; // 默认的连接地址
    private static final int SENDNUM=10; // 发送的消息数量

    public static void main(String[] args) {

        ConnectionFactory connectionFactory; // 连接工厂
        Connection connection = null; // 连接
        Session session; // 会话 接受或者发送消息的线程
        Destination destination; // 消息的目的地
        MessageProducer messageProducer; // 消息生产者

        // 实例化连接工厂
        connectionFactory=new ActiveMQConnectionFactory(JMSProducer.USERNAME, JMSProducer.PASSWORD, JMSProducer.BRO
  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值