zoukankan      html  css  js  c++  java
  • 消息中间件-ActiveMQ入门实例

    1.下载ActiveMQ:

    http://activemq.apache.org/download-archives.html

    2.运行ActiveMQ

    解压缩apache-activemq-5.5.1-bin.zip,然后双击apache-activemq-5.5.1inwin64activemq.bat运行ActiveMQ程序。
    注意:期间若遇到无法启动的情况,请尝试将计算机名改为全英文,不能有其他字符!
    启动以后可浏览器打开一下网址登录,以便后面查看后面程序运行以后的信息!包括消息队列,消息出列,消费者等等信息!
    http://localhost:8161/admin/ (默认用户名和密码是:admin admin)

    3.编写producer和consumer。

    ActiveMQ成功部署运行后,就可以开发producer和consumer了。
    在eclipse中新建Java项目,将ActiveMQ解压目录下的jar包都引入项目(apache-activemq-5.13.0activemq-all-5.13.0.jar),然后就可以编写producer和consumer。

    生产者代码如下:

    package isa.qa.activemqtest;
    
    import javax.jms.Connection;
    import javax.jms.ConnectionFactory;
    import javax.jms.DeliveryMode;
    import javax.jms.Destination;
    import javax.jms.MessageProducer;
    import javax.jms.Session;
    import javax.jms.TextMessage;
    
    import org.apache.activemq.ActiveMQConnection;
    import org.apache.activemq.ActiveMQConnectionFactory;
    
    public class Sender {
        public static void main(String[] args) {
            //ConnectionFactory :连接工厂,JMS用它创建连接
            ConnectionFactory connectionFactory;
            //Connection :JMS 客户端到JMS Provider 的连接
            Connection connection = null;
            //Session: 一个发送或接收消息的线程
            Session session;
            // Destination :消息的目的地;消息发送给谁.
            Destination destination;
            // MessageProducer:消息发送者
            MessageProducer producer;
            // TextMessage message;
            // 构造ConnectionFactory实例对象,此处采用ActiveMq的实现jar
            connectionFactory = new ActiveMQConnectionFactory(
                    ActiveMQConnection.DEFAULT_USER,
                    ActiveMQConnection.DEFAULT_PASSWORD,
                    "tcp://localhost:61616" 
                    );
            try {
                //构造从工厂得到连接对象
                connection = connectionFactory.createConnection();
                //启动
                connection.start();
                //获取操作连接
                session = connection.createSession(Boolean.TRUE, Session.AUTO_ACKNOWLEDGE);
                // 获取session注意参数值是一个服务器的queue/topic
    //            destination = session.createQueue("FirstQueue");
                destination = session.createTopic("FirstTopic");
                // 得到消息生成者【发送者】
                producer = session.createProducer(destination);
                // 持久化的设置,此处学习,实际根据项目决定
                producer.setDeliveryMode(DeliveryMode.PERSISTENT);
                // 构造消息,此处写死,项目就是参数,或者方法获取
                sendMessage(session, producer);
                session.commit();
            } catch (Exception e) {
                e.printStackTrace();
            } finally {
                try {
                    if(null != connection){
                        connection.close();
                    }
                } catch (Throwable ignore) {
                }
            }
        }
    
        public static void sendMessage(Session session, MessageProducer producer) throws Exception{
                TextMessage message = session.createTextMessage("ActiveMq发送的消息");
                //发送消息到目的地方
                System.out.println("ActiveMq发送消息");
                producer.send(message);
        }
    
    }

    消费者代码如下:

    package isa.qa.activemqtest;
    
    import javax.jms.Connection;
    import javax.jms.ConnectionFactory;
    import javax.jms.Destination;
    import javax.jms.MessageConsumer;
    import javax.jms.Session;
    import javax.jms.TextMessage;
    
    import org.apache.activemq.ActiveMQConnection;
    import org.apache.activemq.ActiveMQConnectionFactory;
    
    public class Receiver {
        public static void main(String[] args) {
            // ConnectionFactory :连接工厂,JMS 用它创建连接
            ConnectionFactory connectionFactory;
            // Connection :JMS 客户端到JMS Provider 的连接
            Connection connection = null;
            // Session: 一个发送或接收消息的线程
            Session session;
            // Destination :消息的目的地;消息发送给谁.
            Destination destination;
            // 消费者,消息接收者
            MessageConsumer consumer;
            connectionFactory = new ActiveMQConnectionFactory(
                    ActiveMQConnection.DEFAULT_USER,
                    ActiveMQConnection.DEFAULT_PASSWORD,
                    "tcp://localhost:61616");
            try {
                // 构造从工厂得到连接对象
                connection = connectionFactory.createConnection();
                // 启动
                connection.start();
                // 获取操作连接
                session = connection.createSession(Boolean.FALSE, Session.AUTO_ACKNOWLEDGE);
                // 获取session注意参数值是一个服务器的queue/topic
    //            destination = session.createQueue("FirstQueue");
                destination = session.createTopic("FirstTopic");
                consumer = session.createConsumer(destination);
                while (true) {
                    //设置接收者接收消息的超时时间
                    TextMessage message = (TextMessage) consumer.receive(500000);
                    if (null != message) {
                        System.out.println("收到消息" + message.getText());
                    } else {
                        break;
                    }
                }
            } catch (Exception e) {
                e.printStackTrace();
            } finally {
                try {
                    if (null != connection)
                        connection.close();
                } catch (Throwable ignore) {
                }
            }
        }
    }

    4.注意:

    生产者与消费者之间点对点只需设置:
    destination = session.createQueue("FirstQueue");
    生产者与消费者之间一对多只需设置:
    destination = session.createTopic("FirstTopic");

    集群方式的测试:new ActiveMQConnectionFactory()中

    "admin",             //账号
    "admin123456",  //密码
    "failover:(tcp://182.92.132.128:61616,tcp://182.92.132.109:61616,tcp://182.92.132.153:61616)"    //地址和端口
  • 相关阅读:
    Django的rest_framework的视图之基于通用类编写视图源码解析
    Django的rest_framework的视图之Mixin类编写视图源码解析
    Django1.0和2.0中的rest_framework的序列化组件之超链接字段的处理
    Django的restframework的序列化组件之对单条数据的处理
    Django2.0的path方法无法使用正则表达式的解决办法
    算法的时间复杂度和空间复杂度简单理解
    回归后端分页本质,理清后端分页思路
    SQL Server 2008R2向表中添加字段
    Asp.net IIS 服务器配置远程访问
    linux write 命令
  • 原文地址:https://www.cnblogs.com/007sx/p/5659677.html
Copyright © 2011-2022 走看看