初识ActiveMQ

来源:互联网 发布:浙江省软件协会网站 编辑:程序博客网 时间:2024/06/06 00:51

1:ActiveMQ的安装

ActionMQ的安装三步曲1:进入http://activemq.apache.org/下载,把ActiveMQ的压缩包上传到Linux系统中2:解压3:启动 ./activemq start   关闭 ./activemq stop   查看状态 ./activemq status

这里写图片描述
so easy , 233
2:ActiveMQ的消息形式

对于消息的传递有两种类型:一种是点对点的,即一个生产者和一个消费者一一对应;另一种是发布/订阅模式,即一个生产者产生消息并进行发送后,可以由多个消费者进行接收。JMS定义了五种不同的消息正文格式,以及调用的消息类型,允许你发送并接收以一些不同形式的数据,提供现有消息格式的一些级别的兼容性。  · StreamMessage -- Java原始值的数据流  · MapMessage--一套名称-值对  · TextMessage--一个字符串对象  · ObjectMessage--一个序列化的 Java对象  · BytesMessage--一个字节的数据流

3:ActiveMQ的使用方法
这里写图片描述

4:测试代码

1:Queue1.1.Producer    @Test    public void testQueueProducer() throws Exception {        // 第一步:创建ConnectionFactory对象,需要指定服务端ip及端口号。        //brokerURL服务器的ip及端口号        ConnectionFactory connectionFactory = new ActiveMQConnectionFactory("tcp://192.168.68.133:61616");        // 第二步:使用ConnectionFactory对象创建一个Connection对象。        Connection connection = connectionFactory.createConnection();        // 第三步:开启连接,调用Connection对象的start方法。        connection.start();        // 第四步:使用Connection对象创建一个Session对象。        //第一个参数:是否开启事务。true:开启事务,第二个参数忽略。        //第二个参数:当第一个参数为false时,才有意义。消息的应答模式。1、自动应答2、手动应答。一般是自动应答。        Session session = connection.createSession(false, Session.AUTO_ACKNOWLEDGE);        // 第五步:使用Session对象创建一个Destination对象(topic、queue),此处创建一个Queue对象。        //参数:队列的名称。        Queue queue = session.createQueue("test-queue");        // 第六步:使用Session对象创建一个Producer对象。        MessageProducer producer = session.createProducer(queue);        // 第七步:创建一个Message对象,创建一个TextMessage对象。        /*TextMessage message = new ActiveMQTextMessage();        message.setText("hello activeMq,this is my first test.");*/        TextMessage textMessage = session.createTextMessage("hello activeMq .");        // 第八步:使用Producer对象发送消息。        producer.send(textMessage);        // 第九步:关闭资源。        producer.close();        session.close();        connection.close();    }1.2.Consumer@Test    public void testQueueConsumer() throws Exception {        // 第一步:创建一个ConnectionFactory对象。        ConnectionFactory connectionFactory = new ActiveMQConnectionFactory("tcp://192.168.68.133:61616");        // 第二步:从ConnectionFactory对象中获得一个Connection对象。        Connection connection = connectionFactory.createConnection();        // 第三步:开启连接。调用Connection对象的start方法。        connection.start();        // 第四步:使用Connection对象创建一个Session对象。        Session session = connection.createSession(false, Session.AUTO_ACKNOWLEDGE);        // 第五步:使用Session对象创建一个Destination对象。和发送端保持一致queue,并且队列的名称一致。        Queue queue = session.createQueue("test-queue");        // 第六步:使用Session对象创建一个Consumer对象。        MessageConsumer consumer = session.createConsumer(queue);        // 第七步:接收消息。        consumer.setMessageListener(new MessageListener() {            @Override            public void onMessage(Message message) {                try {                    TextMessage textMessage = (TextMessage) message;                    String text = null;                    //取消息的内容                    text = textMessage.getText();                    // 第八步:打印消息。                    System.out.println(text);                } catch (JMSException e) {                    e.printStackTrace();                }            }        });        //等待键盘输入        System.in.read();        // 第九步:关闭资源        consumer.close();        session.close();        connection.close();
2:Topic2.1 Producer@Test    public void testTopicProducer() throws Exception {        // 第一步:创建ConnectionFactory对象,需要指定服务端ip及端口号。        // brokerURL服务器的ip及端口号        ConnectionFactory connectionFactory = new ActiveMQConnectionFactory("tcp://192.168.68.133:61616");        // 第二步:使用ConnectionFactory对象创建一个Connection对象。        Connection connection = connectionFactory.createConnection();        // 第三步:开启连接,调用Connection对象的start方法。        connection.start();        // 第四步:使用Connection对象创建一个Session对象。        // 第一个参数:是否开启事务。true:开启事务,第二个参数忽略。        // 第二个参数:当第一个参数为false时,才有意义。消息的应答模式。1、自动应答2、手动应答。一般是自动应答。        Session session = connection.createSession(false, Session.AUTO_ACKNOWLEDGE);        // 第五步:使用Session对象创建一个Destination对象(topic、queue),此处创建一个topic对象。        // 参数:话题的名称。        Topic topic = session.createTopic("test-topic");        // 第六步:使用Session对象创建一个Producer对象。        MessageProducer producer = session.createProducer(topic);        // 第七步:创建一个Message对象,创建一个TextMessage对象。        /*         * TextMessage message = new ActiveMQTextMessage(); message.setText(         * "hello activeMq.");         */        TextMessage textMessage = session.createTextMessage("hello activeMq ");        // 第八步:使用Producer对象发送消息。        producer.send(textMessage);        // 第九步:关闭资源。        producer.close();        session.close();        connection.close();    }2.2 Consumer@Test    public void testTopicConsumer() throws Exception {        // 第一步:创建一个ConnectionFactory对象。        ConnectionFactory connectionFactory = new ActiveMQConnectionFactory("tcp://192.168.68.133:61616");        // 第二步:从ConnectionFactory对象中获得一个Connection对象。        Connection connection = connectionFactory.createConnection();        // 第三步:开启连接。调用Connection对象的start方法。        connection.start();        // 第四步:使用Connection对象创建一个Session对象。        Session session = connection.createSession(false, Session.AUTO_ACKNOWLEDGE);        // 第五步:使用Session对象创建一个Destination对象。和发送端保持一致topic,并且话题的名称一致。        Topic topic = session.createTopic("test-topic");        // 第六步:使用Session对象创建一个Consumer对象。        MessageConsumer consumer = session.createConsumer(topic);        // 第七步:接收消息。        consumer.setMessageListener(new MessageListener() {            @Override            public void onMessage(Message message) {                try {                    TextMessage textMessage = (TextMessage) message;                    String text = null;                    // 取消息的内容                    text = textMessage.getText();                    // 第八步:打印消息。                    System.out.println(text);                } catch (JMSException e) {                    e.printStackTrace();                }            }        });        System.out.println("topic的消费端01。。。。。");        // 等待键盘输入        System.in.read();        // 第九步:关闭资源        consumer.close();        session.close();        connection.close();    }

5:小结

Topic1:Publish Subscribe messaging 发布订阅消息2:topic数据默认不落地,是无状态的。3:并不保证publisher发布的每条数据,Subscriber都能接受到。4:一般来说publisher发布消息到某一个topic时,只有正在监听该topic地址的sub能够接收到消息;如果没有sub在监听,该topic就丢失了5:一对多的消息发布接收策略,监听同一个topic地址的多个sub都能收到publisher发送的消息。Sub接收完通知mq服务器Queue1:Point-to-Point 点对点2:Queue数据默认会在mq服务器上以文件形式保存,比如Active MQ一般保存在$AMQ_HOME\data\kr-store\data下面。也可以配置成DB存储。3:Queue保证每条数据都能被receiver接收4:Sender发送消息到目标Queue,receiver可以异步接收这个Queue上的消息。Queue上的消息如果暂时没有receiver来取,也不会丢失。5:一对一的消息发布接收策略,一个sender发送的消息,只能有一个receiver接收。receiver接收完后,通知mq服务器已接收,mq服务器对queue里的消息采取删除或其他操作。