activeMQ多线程并发 p2p 简单封装

工具类:

package util;

import javax.jms.Connection;
import javax.jms.ConnectionFactory;
import javax.jms.JMSException;
import javax.jms.MessageConsumer;
import javax.jms.MessageProducer;
import javax.jms.Queue;
import javax.jms.Session;
import javax.jms.TextMessage;

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

public class ThreadActiveMqUtil {

    private static final ThreadActiveMqUtil threadActiveMqUtil = new ThreadActiveMqUtil();

    private ThreadActiveMqUtil() {

    }

    public static ThreadActiveMqUtil getThreadActiveMqUtil(){
        return threadActiveMqUtil;
    }

    private ConnectionFactory connectionFactory = null;
    private Connection connection = null;
    private Session session = null;
    private Queue queue = null;



    ThreadLocal<MessageProducer> tlpro = new ThreadLocal<MessageProducer>();
    ThreadLocal<MessageConsumer> tlcon = new ThreadLocal<MessageConsumer>();
    ThreadLocal<Integer> tlCount = new ThreadLocal<Integer>();

    /**
     * 实例化链接通道
     * @param userName
     * @param passWord
     * @param url
     */
    public void init(String userName,String passWord,String url){
        connectionFactory = new ActiveMQConnectionFactory(userName, passWord, url);
        try {
            connection = connectionFactory.createConnection();
            connection.start();
        } catch (JMSException e) {
            e.printStackTrace();
        }
    }

    /**
     * 发送消息
     * @param name 队列名字
     */
    public void p2pProduce(String name){
        try {
            session = connection.createSession(true, Session.SESSION_TRANSACTED);
            queue = session.createQueue(name);
            MessageProducer producer = tlpro.get();
            Integer num = tlCount.get();
            if(producer == null){
                producer = session.createProducer(queue);
                tlpro.set(producer);
            }
            if(num == null){
                num = 0;
                tlCount.set(num);
            }

            while(true){
                TextMessage message = session.createTextMessage(Thread.currentThread().getName()+num+":发送信息-");
                System.out.println(Thread.currentThread().getName()+"-"+num+":发送信息-");
                producer.send(message);
                session.commit();
                num++;
            }
        } catch (JMSException e) {
            e.printStackTrace();
        }

    }

    /**
     * 接收消息
     * @param name
     */
    public void p2pComsumer(String name){
        try {
            session = connection.createSession(Boolean.FALSE, Session.AUTO_ACKNOWLEDGE);
            queue = session.createQueue(name);
            MessageConsumer consumer = tlcon.get();
            Integer num = tlCount.get();
            if(consumer == null){
                consumer = session.createConsumer(queue);
                tlcon.set(consumer);
            }
            if(num == null){
                num = 0;
                tlCount.set(num);
            }

            while(true){
                TextMessage message = (TextMessage) consumer.receive();
                if(message != null){
                    message.acknowledge();//接收到消息,返回一个应答
                    System.out.println(Thread.currentThread().getName()+"-"+num+"-接收消息:"+message);
                    Thread.sleep(500);
                    num++;
                }
            }
        } catch (JMSException e) {
            e.printStackTrace();
        } catch (InterruptedException e) {
            e.printStackTrace();
        }
    }

    /**
     * 关闭链接
     * @param con
     */
    public void closeCon(Connection con){
        if(con != null){
            try {
                con.close();
            } catch (JMSException e) {
                e.printStackTrace();
            }
        }
    }
}

生产者-demo:

package threadDemo;

import org.apache.activemq.ActiveMQConnection;

import util.ThreadActiveMqUtil;

public class ThreadProducer {

    private static final String userName = ActiveMQConnection.DEFAULT_USER;
    private static final String passWord = ActiveMQConnection.DEFAULT_PASSWORD;
    private static final String url = ActiveMQConnection.DEFAULT_BROKER_URL;

    public static void main(String[] args) {
        ThreadProducer t = new ThreadProducer();

        new Thread(t.new ThreadPro()).start();
        new Thread(t.new ThreadPro()).start();
        new Thread(t.new ThreadPro()).start();
    }

    private class ThreadPro implements Runnable{
        public void run() {
            ThreadActiveMqUtil threadActiveMqUtil = ThreadActiveMqUtil.getThreadActiveMqUtil();
            threadActiveMqUtil.init(userName, passWord, url);
            threadActiveMqUtil.p2pProduce("通道1");
        }

    }

}

消费者-demo:

package threadDemo;

import org.apache.activemq.ActiveMQConnection;

import util.ThreadActiveMqUtil;

public class ThreadConsumer {

    private static final String userName = ActiveMQConnection.DEFAULT_USER;
    private static final String passWord = ActiveMQConnection.DEFAULT_PASSWORD;
    private static final String url = ActiveMQConnection.DEFAULT_BROKER_URL;

    public static void main(String[] args) {
        ThreadConsumer t = new ThreadConsumer();

        new Thread(t.new ThreadCon(),"1t").start();
        new Thread(t.new ThreadCon(),"2t").start();
        new Thread(t.new ThreadCon(),"3t").start();
    }

    private class ThreadCon implements Runnable{
        public void run() {
            ThreadActiveMqUtil threadActiveMqUtil = ThreadActiveMqUtil.getThreadActiveMqUtil();
            threadActiveMqUtil.init(userName, passWord, url);
            threadActiveMqUtil.p2pComsumer("通道1");
        }

    }
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值