Java中间消息件ActiveMQ怎么用

发布时间:2021-09-28 14:46:24 作者:小新
来源:亿速云 阅读:155

这篇文章将为大家详细讲解有关Java中间消息件ActiveMQ怎么用,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。

什么是中间消息间吧。

采用消息传送机制/消息队列 的中间件技术,进行数据交流,用在分布式系统的集成。Java中对Jms有了定义,这是Java消息的统一接口。什么是ActiveMq呢?这是这个接口的一种实现,相当于数据库连接驱动一样,不同厂商有自己不同的实现,我们尽快看怎么用代码实现吧。

消息一共有两种接收和发送形式:点对点和发布定阅模式,也就是“一对一”和“一对多”。

1.导包(maven):

<dependency>      <groupId>org.apache.activemq</groupId>      <artifactId>activemq-client</artifactId>      <version>5.13.4</version>    </dependency>

2.开始写类,提供者(发送者)和消费者(接收者)是两个不同的项目,我们先创建普通的maven项目,而不是web项目点对点的方式(消息只能被消费一次,如果同时有多个消费者,谁先抢到就是谁的)

消息提供者

public static void main(String[] args) throws JMSException {    //创建连接工厂,这个参数就是自己的activeMQ的地址    ConnectionFactory connectionFactory = new ActiveMQConnectionFactory("tcp://192.168.25.180:61616");    //2.创建连接    Connection connection = connectionFactory.createConnection();    //3.启动连接    connection.start();    //4.获取session(会话对象)    /*    arg0 是否启用事务    arg1 消息的确认方式 自动确认     */    Session session = connection.createSession(false,Session.AUTO_ACKNOWLEDGE);    //5.创建一个队列对象,名称    Queue firstQueue = session.createQueue("firstQueue");    //6.创建一个消息的生产者对象//    Destination destination = ;//目标对象    MessageProducer producer = session.createProducer(firstQueue);    //7.创建一个消息    TextMessage textMessage = session.createTextMessage("欢迎来到奇的天喻软件");    //8.发送消息    producer.send(textMessage);    //9.关闭资源    producer.close();    session.close();    connection.close();  }

消息消费者

前几步是一样的,都是创建连接,只有第6步不一样,创建的是一个消费者

public static void main(String[] args) throws JMSException, IOException {    ConnectionFactory connectionFactory = new ActiveMQConnectionFactory("tcp://192.168.25.180:61616");    //2.创建连接    Connection connection = connectionFactory.createConnection();    //3.启动连接    connection.start();    //4.获取session(会话对象)    /*    arg0 是否启用事务    arg1 消息的确认方式 自动确认     */    Session session = connection.createSession(false,Session.AUTO_ACKNOWLEDGE);    //5.创建一个队列对象,名称    Queue firstQueue = session.createQueue("firstQueue");    //6.创建消息消费者对象    MessageConsumer consumer = session.createConsumer(firstQueue);    //7.设置监听    consumer.setMessageListener(new MessageListener() {      @Override      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();  }

发布订阅模式(发布消息后,只有在之前运行的消费者才能收到,消息被任何一个消费者消费后,以后启动的消费者不能消费之前的消息)

消息提供者

//创建连接工厂    ConnectionFactory connectionFactory = new ActiveMQConnectionFactory("tcp://192.168.25.180:61616");    //2.创建连接    Connection connection = connectionFactory.createConnection();    //3.启动连接    connection.start();    //4.获取session(会话对象)    /*    arg0 是否启用事务    arg1 消息的确认方式 自动确认     */    Session session = connection.createSession(false,Session.AUTO_ACKNOWLEDGE);    //5    Topic topic = session.createTopic("first-topic");    //6.创建一个消息的生产者对象//    Destination destination = ;//目标对象    MessageProducer producer = session.createProducer(topic);    //7.创建一个消息    TextMessage textMessage = session.createTextMessage("欢迎来到奇的天喻软件");    //8.发送消息    producer.send(textMessage);    //9.关闭资源    producer.close();    session.close();    connection.close();

消费者

ConnectionFactory connectionFactory = new ActiveMQConnectionFactory("tcp://192.168.25.180:61616");    //2.创建连接    Connection connection = connectionFactory.createConnection();    //3.启动连接    connection.start();    //4.获取session(会话对象)    /*    arg0 是否启用事务    arg1 消息的确认方式 自动确认     */    Session session = connection.createSession(false,Session.AUTO_ACKNOWLEDGE);    //5    Topic topic = session.createTopic("first-topic");    //6.创建消息消费者对象    MessageConsumer consumer = session.createConsumer(topic);    //7.设置监听    consumer.setMessageListener(new MessageListener() {      @Override      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();

关于“Java中间消息件ActiveMQ怎么用”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,使各位可以学到更多知识,如果觉得文章不错,请把它分享出去让更多的人看到。

推荐阅读:
  1. 消息中间件面试题31道RabbitMQ+ActiveMQ+Kafka
  2. 消息中间件概述

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

java activemq

上一篇:CentOS的简介与历史是怎样的

下一篇:以单用户模式启动CentOS/RHEL 7/8 的三种方法是怎样的

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》