activeMQ创建生产者与消费者

普通web项目,未使用maven

配置文件:default.properties,放到conf下就行。
#----  activeMQ配置参数    ----------------------
AMQ_USER = admin
AMQ_PASSWORD = admin
#URL = ActiveMQConnection.DEFAULT_BROKER_URL;
AMQ_URL = failover://tcp://192.168.42.147:61616
AMQ_SUBJECT = ActiveMQ.Demo
#----  activeMQ配置参数    ----------------------

消费者:jmsReceiver
 
  
package com.cn.cncc.activeMQ;

import java.util.Enumeration;

import javax.jms.BytesMessage;
import javax.jms.Connection;
import javax.jms.Destination;
import javax.jms.JMSException;
import javax.jms.MapMessage;
import javax.jms.Message;
import javax.jms.MessageConsumer;
import javax.jms.MessageListener;
import javax.jms.ObjectMessage;
import javax.jms.Session;
import javax.jms.StreamMessage;
import javax.jms.TextMessage;

import org.apache.activemq.ActiveMQConnectionFactory;

import com.cn.cncc.util.PropertiesUtils;

/**
 * 说明:
 * 
 * @author hjr
 * @version 创建时间:2017-3-22 下午1:22:40S
 */
public class JmsReceiver implements MessageListener {

	private Destination dest = null;
	private Connection conn = null;
	private Session session = null;
	private MessageConsumer consumer = null;

	private boolean stop = false;
	
	// 初始化
	private void initialize() throws JMSException, Exception {
		//读取上面配置文件中的内容
		PropertiesUtils.readProperties("default.properties");
		String USER = PropertiesUtils.getProperty("AMQ_USER");;
		String PASSWORD = PropertiesUtils.getProperty("AMQ_PASSWORD");;
		// private String URL = ActiveMQConnection.DEFAULT_BROKER_URL;
		String URL = PropertiesUtils.getProperty("AMQ_URL");// localhost
		String SUBJECT = PropertiesUtils.getProperty("AMQ_SUBJECT");
		
		// 连接工厂是用户创建连接的对象.
		ActiveMQConnectionFactory connectionFactory = new ActiveMQConnectionFactory(
				USER, PASSWORD, URL);
		// 连接工厂创建一个jms connection
		conn = connectionFactory.createConnection();
		// 是生产和消费的一个单线程上下文。会话用于创建消息的生产者,消费者和消息。
		session = conn.createSession(false, Session.AUTO_ACKNOWLEDGE); 
		//dest是客户用来指定他生产消息的目标还有他消费消息的来源的对象.
		dest = session.createQueue(SUBJECT);
		// dest = session.createTopic(SUBJECT);
		// 会话创建消息的生产者将消息发送到目的地
		consumer = session.createConsumer(dest);
	}
	public JmsReceiver() throws Exception {  
	    initialize();  
	  }  
	/**
	 * 消费消息
	 * 
	 * @throws JMSException
	 * @throws Exception
	 */
	public void receiveMessage() throws JMSException, Exception {
		//线程启动
		conn.start();
		consumer.setMessageListener(this);
		// 等待接收消息
		while (!stop) {
			Thread.sleep(1000);
		}

	}

	@SuppressWarnings("rawtypes")
	@Override
	public void onMessage(Message msg) {
		try {
			
			TextMessage message = (TextMessage) msg;
			System.out.println("------Received TextMessage------");
			System.out.println(message.getText());
				
			stop = true;
		} catch (JMSException e) {
			e.printStackTrace();
		} finally {
			try {
				this.close();
			} catch (JMSException e) {
				e.printStackTrace();
			}
		}
	}

	// 关闭连接
	public void close() throws JMSException {
		System.out.println("Consumer:->Closing connection");
		if (consumer != null)
			consumer.close();
		if (session != null)
			session.close();
		if (conn != null)
			conn.close();
	}
}
生产者:
 
  
package com.cn.cncc.activeMQ;

import javax.jms.BytesMessage;
import javax.jms.Connection;
import javax.jms.DeliveryMode;
import javax.jms.Destination;
import javax.jms.JMSException;
import javax.jms.MapMessage;
import javax.jms.MessageProducer;
import javax.jms.ObjectMessage;
import javax.jms.Session;
import javax.jms.StreamMessage;
import javax.jms.TextMessage;

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

/**
 * 说明: activemq send message
 * 
 * @author hjr
 * @version 创建时间:2017-3-22 下午1:22:40
 */
public class JmsSender {
	//其实也可以从配置文件读取的
	private String USER = ActiveMQConnection.DEFAULT_USER;//admin
	private String PASSWORD = ActiveMQConnection.DEFAULT_PASSWORD;//admin
	//private String URL = ActiveMQConnection.DEFAULT_BROKER_URL;//localhost
	private String URL = "failover://tcp://192.168.42.147:61616";//localhost
	private String SUBJECT = "ActiveMQ.Demo";

	private Destination destination = null;
	private Connection conn = null;
	private Session session = null;
	private MessageProducer producer = null;

	// 初始化
	private void initialize() throws JMSException, Exception {
		// 连接工厂
		ActiveMQConnectionFactory connectionFactory = new ActiveMQConnectionFactory(
				USER, PASSWORD, URL);
		conn = connectionFactory.createConnection();
		// 事务性会话,自动确认消息
		session = conn.createSession(false, Session.AUTO_ACKNOWLEDGE);
		// 消息的目的地(Queue/Topic)
		destination = session.createQueue(SUBJECT);
		// destination = session.createTopic(SUBJECT);
		// 消息的提供者(生产者)
		producer = session.createProducer(destination);
		// 不持久化消息
		producer.setDeliveryMode(DeliveryMode.NON_PERSISTENT);
	}

	public void sendMessage(String msgType) throws JMSException, Exception {
		initialize();
		// 连接到JMS提供者(服务器)
		conn.start();
		for (int i = 0; i < 100; i++) {
			// 发送文本消息
			if ("text".equals(msgType)) {
				String textMsg = "ActiveMQ Text Message!";
				TextMessage msg = session.createTextMessage();
				// TextMessage msg = session.createTextMessage(textMsg);
				msg.setText(textMsg);
				producer.send(msg);
			}
		}
		
	}

	// 关闭连接
	public void close() throws JMSException {
		if (producer != null)
			producer.close();
		if (session != null)
			session.close();
		if (conn != null)
			conn.close();
	}

}

PropertiesUtils工具类:

package com.cn.cncc.util;

import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.util.Properties;
/**
 * @name PropertiesUtils
 * @description 读取配置文件工具类
 * @author hjr
 * @createDate 2016-11-24
 */
public class PropertiesUtils {

	private static Properties _prop = new Properties();

    /**
     * @name readProperties
     * @description 读取配置文件
     * @author hjr
     * @createDate 2016-11-24
     * @param fileName
     */
    public static void readProperties(String fileName){
        try {
            InputStream in = PropertiesUtils.class.getResourceAsStream("/"+fileName);
            BufferedReader bf = new BufferedReader(new InputStreamReader(in));
            _prop.load(bf);
        }catch (IOException e){
            e.printStackTrace();
        }
    }

    /**
     * @name getProperty
     * @description 根据key读取对应的value
     * @author hjr
     * @createDate 2016-11-24
     * @param key
     * @return String
     */
    public static String getProperty(String key){
        return _prop.getProperty(key);
    }

}
测试类:
 
  
package com.cn.cncc.activeMQ;

import javax.jms.JMSException;

import javax.jms.Connection;

/**
 * 说明:
 * 
 * @author hjr
 * @version 创建时间:2017-03-22 下午4:33:17
 */
public class Test {
	static Connection mqConnection;

	public static void main(String[] args) throws JMSException, Exception {
		JmsSender sender = new JmsSender();
		sender.sendMessage("map");
		sender.close();
		
		
		JmsReceiver receiver = new JmsReceiver();
		receiver.receiveMessage();
		receiver.close();
	}
}
有时会报 NoClassDefFoundError 错误,可将下面两个包放到lib文件夹下,并buildpath.activeMQ创建生产者与消费者_第1张图片
javax.jms.jar、javax.management.j2ee.jar,

 
 

你可能感兴趣的:(activeMQ创建生产者与消费者)