ActiveMQ入门:点对点模型

消息生产者:

import org.apache.activemq.ActiveMQConnection;
import org.apache.activemq.ActiveMQConnectionFactory;

import javax.jms.*;


public class Producer {
    private static final String USERNAME= ActiveMQConnection.DEFAULT_USER; //默认连接用户名
    private static final String PASSWORD=ActiveMQConnection.DEFAULT_PASSWORD;//默认连接密码
    private static final String BROKER_URL=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; //消息生产者

        try {
            connectionFactory=new ActiveMQConnectionFactory(USERNAME,PASSWORD,BROKER_URL);
            connection=connectionFactory.createConnection(); //通过连接工厂获取连接
            connection.start(); //启动连接
            //第一个参数表示是否开启事务,第二个表示确认事务的方式
            session=connection.createSession(true,Session.AUTO_ACKNOWLEDGE); //创建Session
            destination=session.createQueue("FirstQueue"); //创建消息队列
            messageProducer=session.createProducer(destination);//创建消息生产者
            sendMessage(session,messageProducer);  //发送消息
            session.commit(); //由于开启了事务,所以要提交事务
        } catch (JMSException e) {
            e.printStackTrace();
        } finally {
            if (connection!=null){
                try {
                    connection.close();
                } catch (JMSException e) {
                    e.printStackTrace();
                }
            }
        }

    }

    //发送消息
    private static void sendMessage(Session session,MessageProducer messageProducer){

        try {
            for (int i = 0; i < SENDNUM; i++) {
                TextMessage message=session.createTextMessage("ActiveMQ 发送的消息"+i);
                System.out.println("发送的消息 : ActiveMQ 发送的消息"+i);
                messageProducer.send(message);  //发送消息
            }

        } catch (JMSException e){
            e.printStackTrace();
        }
    }
}

消息消费者:

import org.apache.activemq.ActiveMQConnection;
import org.apache.activemq.ActiveMQConnectionFactory;

import javax.jms.*;


public class Customer {
    private static final String USERNAME= ActiveMQConnection.DEFAULT_USER; //默认连接用户名
    private static final String PASSWORD=ActiveMQConnection.DEFAULT_PASSWORD;//默认连接密码
    private static final String BROKER_URL=ActiveMQConnection.DEFAULT_BROKER_URL;//默认连接地址

    public static void main(String[] args) {
        ConnectionFactory connectionFactory;
        Connection connection=null;
        Session session; //接收或发送消息
        Destination destination; //消息的目的地
        MessageConsumer messageConsumer; //消息消费者

        try {
            connectionFactory=new ActiveMQConnectionFactory(USERNAME,PASSWORD,BROKER_URL);
            connection=connectionFactory.createConnection();
            connection.start();
            session=connection.createSession(false,Session.AUTO_ACKNOWLEDGE);
            destination=session.createQueue("FirstQueue"); //创建连接的消息队列
            messageConsumer=session.createConsumer(destination);
            /*while (true){
                TextMessage textMessage= (TextMessage) messageConsumer.receive(1000);
                if (textMessage!=null){
                    System.out.println("收到的消息:"+textMessage.getText());
                }
                else {
                    break;
                }
            }*/
            messageConsumer.setMessageListener(new Listener()); //注册消息监听

        } catch (JMSException e){
            e.printStackTrace();
        }
    }

}

监听器:

import javax.jms.JMSException;
import javax.jms.Message;
import javax.jms.MessageListener;
import javax.jms.TextMessage;


public class Listener implements MessageListener{

    //消息监听
    @Override
    public void onMessage(Message message) {
        try {
            System.out.println("收到的消息: "+((TextMessage)message).getText());

        } catch (JMSException e) {
            e.printStackTrace();
        }
    }
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值