AtiviMQ 消息队列处理


消息生产者

package com.zuk.activemq.demo;

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.ActiveMQConnectionFactory;
import org.apache.activemq.command.ActiveMQMessage;

public class Sender {
	
	public static void main(String[] args) throws Exception{
		
		/*
		 * 创建ConnectionFactory工厂对象,填入用户、密码
		 */
		ConnectionFactory connectionFactory = new ActiveMQConnectionFactory(
					ActiveMQConnectionFactory.DEFAULT_USER, 
					ActiveMQConnectionFactory.DEFAULT_PASSWORD, 
					"tcp://localhost:61616");
		
		/*
		 * 根据ConnectionFactory创建一个connect连接
		 */
		Connection connection = connectionFactory.createConnection();
		connection.start();
		
		/* 创建Session回话
		 * 
		 * Boolean.FALSE 无事务操作  无session操作
		 * Boolean.TRUE 事务操作  session.commit();或者 session.rollback();
		 * 
		 * Session.AUTO_ACKNOWLEDGE  自动确认模式
		 * Session.CLIENT_ACKNOWLEDGE 手工确认模式
		 */
		Session session = connection.createSession(Boolean.TRUE, Session.CLIENT_ACKNOWLEDGE);
		
		/*
		 *通过Session创建Destination对象,指的是一个客户端用来产生消息目标和消费消息来源的对象,
		 *在PTP模式中,Destination是queue
		 *在public/descripe中是topic
		 * */
		Destination destination = session.createQueue("hongjia.mis.mail.queue");
		
		/*
		 * 通过Session创建消息的发送者MessageProducer和接受者MessageConsumer
		 * */
		MessageProducer messageProducer =  session.createProducer(destination);
		
		/*
		 * 通过DeliveryMode设置消息的持久(写入数据库中)和非持久化特性
		 * 
		 * NON_PERSISTENT 不写入数据库中
		 * 
		 * PERSISTENT 写入数据库中
		 * 
		 * */
		messageProducer.setDeliveryMode(DeliveryMode.NON_PERSISTENT);
		
//		/*
//		 * 设置消息的数据类型
//		 * TestMessage
//		 * 
//		 * */
//		TextMessage textMessage = session.createTextMessage();
//		textMessage.setText("hello world.");
//		
//		/*
//		 * 发送消息 
//		 * */
//		messageProducer.send(textMessage);
		
		
		for (int i=0; i<50;i++) {
			/*
			 * 设置消息的数据类型
			 * TestMessage
			 * 
			 * */
			TextMessage textMessage = session.createTextMessage();
			textMessage.setText("hello world "+i+" 次");
			System.out.println("生产者生产消息:" + "hello world "+i+" 次");
			/*
			 * 发送消息 
			 * */
			messageProducer.send(textMessage);
			
		}
		
		//事务方式提交操作
		session.commit();
		
		//关闭
		if(connection!=null){
			connection.close();
		}
		
	}
	
}


消费者

package com.zuk.activemq.demo;

import javax.jms.Connection;
import javax.jms.ConnectionFactory;
import javax.jms.DeliveryMode;
import javax.jms.Destination;
import javax.jms.MessageConsumer;
import javax.jms.MessageProducer;
import javax.jms.Session;
import javax.jms.TextMessage;

import org.apache.activemq.ActiveMQConnectionFactory;

public class Receiver {
	

	
	public static void main(String[] args) throws Exception{
		
		/*
		 * 创建ConnectionFactory工厂对象,填入用户、密码
		 */
		ConnectionFactory connectionFactory = new ActiveMQConnectionFactory(
					ActiveMQConnectionFactory.DEFAULT_USER, 
					ActiveMQConnectionFactory.DEFAULT_PASSWORD, 
					"tcp://localhost:61616");
		
		/*
		 * 根据ConnectionFactory创建一个connect连接
		 */
		Connection connection = connectionFactory.createConnection();
		connection.start();
		
		/*创建Session回话
		 * 
		 * Boolean.FALSE 无事务操作  无session操作
		 * Boolean.TRUE 事务操作  session.commit();或者 session.rollback();
		 * 
		*Session.AUTO_ACKNOWLEDGE  自动确认模式
		*Session.CLIENT_ACKNOWLEDGE 手工确认模式
		*/
		Session session = connection.createSession(Boolean.TRUE, Session.AUTO_ACKNOWLEDGE);
		
		/*
		 *通过Session创建Destination对象,指的是一个客户端用来产生消息目标和消费消息来源的对象,
		 *在PTP模式中,Destination是queue
		 *在public/descripe中是topic
		 * */
		Destination destination = session.createQueue("hongjia.mis.mail.queue");
		
		/*
		 * 通过Session创建消息的发送者MessageProducer和接受者MessageConsumer
		 * */
		MessageConsumer messageConsumer = session.createConsumer(destination);
		System.out.println("开始消费.");
		int iii=0;
		while(true){
			
			if(iii>=20){
				break;
			}else{
				iii++;
			}
			
			TextMessage textMessage = (TextMessage) messageConsumer.receive();
			if(textMessage==null){
				break;
			}
			Thread.sleep(1000);
			System.out.println("消费者:"+textMessage.getText());
			//手动确认签收
			textMessage.acknowledge();
			session.commit();
			
		}
		
		
		
		//关闭
		if(connection!=null){
			connection.close();
		}
		
	}
	

	
}





  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值