IMOOC activeMQ 学习笔记

学习地址 : http://www.imooc.com/video/15221

maven地址: http://mvnrepository.com/artifact/org.apache.activemq/activemq-all/5.14.5

activeMQ官网:http://activemq.apache.org/



windows下运行方法

  • 64位目录:apache-activemq-5.15.0-bin\apache-activemq-5.15.0\bin\win64
  • activemq.bat 为窗口模式执行activemq,当窗口被关闭,则退出。
  • InstallService.bat 安装到系统服务,运行后到services.exe中找到activemq并启动,即可后台运行
  • UninstallService.bat 对应上一条为卸载系统服务


模式1

queue 队列模式

当发布者发布消息后,接收者是平分发布的消息

queue 队列模式 发布者示例代码

package com.bumblebee.jms.queue;

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.ActiveMQConnectionFactory;

public class AppProducer {
	private static final String url = "tcp://127.0.0.1:61616";
	private static final String queueName = "queue-test";
	public static void main(String[] args) throws JMSException {
		//1.创建ConnectionFactory
		ConnectionFactory connectionFactory = new ActiveMQConnectionFactory(url);
		
		//2.创建Connection
		Connection connection = connectionFactory.createConnection();
		
		//3.启动连接
		connection.start();
		
		//4.创建会话		参数1:是否在事务中处理		参数2:应答模式,自动应答
		Session session = connection.createSession(false, Session.AUTO_ACKNOWLEDGE);
		
		//5.创建一个目标	Queue 队列模式
		Destination destination = session.createQueue(queueName);
		
		//6.创建一个生产者
		MessageProducer producer = session.createProducer(destination);
		
		//循环发送消息
		for (int i = 0; i < 100; i++) {
			//7.创建消息
			TextMessage textMessage = session.createTextMessage("test"+i);
			
			//8.发布消息
			producer.send(textMessage);
			
			System.out.println("发送消息:"+textMessage.getText());
		}
		
		//9.关闭连接
		connection.close();
	}
}


queue 队列模式 接收者示例代码

package com.bumblebee.jms.queue;

import javax.jms.Connection;
import javax.jms.ConnectionFactory;
import javax.jms.Destination;
import javax.jms.JMSException;
import javax.jms.Message;
import javax.jms.MessageConsumer;
import javax.jms.MessageListener;
import javax.jms.MessageProducer;
import javax.jms.Session;
import javax.jms.TextMessage;

import org.apache.activemq.ActiveMQConnectionFactory;

public class AppConsumer {
	private static final String url = "tcp://127.0.0.1:61616";
	private static final String queueName = "queue-test";
	public static void main(String[] args) throws JMSException {
		//1.创建ConnectionFactory
		ConnectionFactory connectionFactory = new ActiveMQConnectionFactory(url);
		
		//2.创建Connection
		Connection connection = connectionFactory.createConnection();
		
		//3.启动连接
		connection.start();
		
		//4.创建会话		参数1:是否在事务中处理		参数2:应答模式,自动应答
		Session session = connection.createSession(false, Session.AUTO_ACKNOWLEDGE);
		
		//5.创建一个目标
		Destination destination = session.createQueue(queueName);
		
		//6.创建一个消费者
		MessageConsumer consumer = session.createConsumer(destination);
		
		//7.创建一个监听器
		consumer.setMessageListener(new MessageListener() {
			public void onMessage(Message message) {
				TextMessage textMessage = (TextMessage) message;
				try {
					System.out.println("接收消息:"+textMessage.getText());
				} catch (JMSException e) {
					e.printStackTrace();
				}
			}
		});
		
		//8.关闭连接
		//connection.close();
	}
}


模式2

Topic 主题模式

当发布者发布消息后,所有接收者都能接收到全部消息


Topic 主题模式 发布者 示例代码

package com.bumblebee.jms.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.ActiveMQConnectionFactory;

public class AppProducer {
	private static final String url = "tcp://127.0.0.1:61616";
	private static final String topicName = "topic-test";
	public static void main(String[] args) throws JMSException {
		//1.创建ConnectionFactory
		ConnectionFactory connectionFactory = new ActiveMQConnectionFactory(url);
		
		//2.创建Connection
		Connection connection = connectionFactory.createConnection();
		
		//3.启动连接
		connection.start();
		
		//4.创建会话		参数1:是否在事务中处理		参数2:应答模式,自动应答
		Session session = connection.createSession(false, Session.AUTO_ACKNOWLEDGE);
		
		//5.创建一个目标 	Topic 主题模式
		Destination destination = session.createTopic(topicName);
		
		//6.创建一个生产者
		MessageProducer producer = session.createProducer(destination);
		
		//循环发送消息
		for (int i = 0; i < 100; i++) {
			//7.创建消息
			TextMessage textMessage = session.createTextMessage("test"+i);
			
			//8.发布消息
			producer.send(textMessage);
			
			System.out.println("发送消息:"+textMessage.getText());
		}
		
		//9.关闭连接
		connection.close();
	}
}


Topic 主题模式 接收者 示例代码

package com.bumblebee.jms.topic;

import javax.jms.Connection;
import javax.jms.ConnectionFactory;
import javax.jms.Destination;
import javax.jms.JMSException;
import javax.jms.Message;
import javax.jms.MessageConsumer;
import javax.jms.MessageListener;
import javax.jms.MessageProducer;
import javax.jms.Session;
import javax.jms.TextMessage;

import org.apache.activemq.ActiveMQConnectionFactory;

public class AppConsumer {
	private static final String url = "tcp://127.0.0.1:61616";
	private static final String topicName = "topic-test";
	public static void main(String[] args) throws JMSException {
		//1.创建ConnectionFactory
		ConnectionFactory connectionFactory = new ActiveMQConnectionFactory(url);
		
		//2.创建Connection
		Connection connection = connectionFactory.createConnection();
		
		//3.启动连接
		connection.start();
		
		//4.创建会话		参数1:是否在事务中处理		参数2:应答模式,自动应答
		Session session = connection.createSession(false, Session.AUTO_ACKNOWLEDGE);
		
		//5.创建一个目标
		Destination destination = session.createTopic(topicName);
		
		//6.创建一个消费者
		MessageConsumer consumer = session.createConsumer(destination);
		
		//7.创建一个监听器
		consumer.setMessageListener(new MessageListener() {
			public void onMessage(Message message) {
				TextMessage textMessage = (TextMessage) message;
				try {
					System.out.println("接收消息:"+textMessage.getText());
				} catch (JMSException e) {
					e.printStackTrace();
				}
			}
		});
		
		//8.关闭连接
		//connection.close();
	}
}





赠人玫瑰 手留余香
github初识
imooc idea 教程
立即登录, 发表评论.
没有帐号? 立即注册
0 条评论