activemq 重启后java程序_ActiveMQ,java程序员不得不懂的技术

常见的消息队列

随着互联网时代的发展,系统架构由单台服务器进化到多台服务器,在发展到微服务,分布式架构。此时的系统对于消息队列的应用也是愈发依赖。

今天我们常用的消息队列由rabbitmq,redis,kafka以及今天我们要说的 activemq。

activemq 重启后java程序_ActiveMQ,java程序员不得不懂的技术_第1张图片

code

ActiveMQ

ActiveMQ 是Apache出品,最流行的,能力强劲的开源消息总线。ActiveMQ 是一个完全支持JMS1.1和J2EE 1.4规范的 JMS Provider实现,尽管JMS规范出台已经是很久的事情了,但是JMS在当今的J2EE应用中间仍然扮演着特殊的地位。

ActiveMQ的简单应用

maven依赖:javax.jmsjms1.1org.apache.activemqactivemq-core5.7.0org.apache.activemqactivemq-pool5.7.0

下面是ActiveMQ的简单应用,上面已经添加了注释:

生产者:package com.guanglan.mq;import javax.jms.Connection;import javax.jms.ConnectionFactory;import javax.jms.JMSException;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;/* Created by GuangLan on 2017/12/17.*/public class Producter {//ActiveMq 的默认用户名private static final String USERNAME = ActiveMQConnection.DEFAULT_USER;//ActiveMq 的默认登录密码private static final String PASSWORD = ActiveMQConnection.DEFAULT_PASSWORD;//ActiveMQ 的链接地址private static final String BROKEN_URL = ActiveMQConnection.DEFAULT_BROKER_URL;//链接工厂private ConnectionFactory connectionFactory;//链接对象private Connection connection;//事务管理private Session session;public void init(){try {//创建一个链接工厂connectionFactory = new ActiveMQConnectionFactory(USERNAME,PASSWORD,BROKEN_URL);//从工厂中创建一个链接connection = connectionFactory.createConnection();//开启链接connection.start();//创建一个事务(这里通过参数可以设置事务的级别)session = connection.createSession(true,Session.SESSION_TRANSACTED);} catch (JMSException e) {e.printStackTrace();}}//创建队列并发送消息public void sendMessage(String queueName , String msg) throws InterruptedException{try {//创建一个消息队列Queue queue = session.createQueue(queueName);//消息生产者MessageProducer messageProducer = session.createProducer(queue);//创建一条消息TextMessage sendMsg = session.createTextMessage(msg);//发送消息messageProducer.send(sendMsg);//提交事务session.commit();} catch (JMSException e) {e.printStackTrace();}}}

消费者:package com.guanglan.mq;import javax.jms.Connection;import javax.jms.ConnectionFactory;import javax.jms.JMSException;import javax.jms.Message;import javax.jms.MessageConsumer;import javax.jms.MessageListener;import javax.jms.Queue;import javax.jms.Session;import javax.jms.TextMessage;import org.apache.activemq.ActiveMQConnection;import org.apache.activemq.ActiveMQConnectionFactory;/* Created by GuangLan on 2017/12/17.*/public class Comsumer {//ActiveMq 的默认用户名private static final String USERNAME = ActiveMQConnection.DEFAULT_USER;//ActiveMq 的默认登录密码private static final String PASSWORD = ActiveMQConnection.DEFAULT_PASSWORD;//ActiveMQ 的链接地址private static final String BROKEN_URL = ActiveMQConnection.DEFAULT_BROKER_URL;private ConnectionFactory connectionFactory;private Connection connection;private Session session;public void init(){try {//创建一个链接工厂connectionFactory = new ActiveMQConnectionFactory(USERNAME,PASSWORD,BROKEN_URL);//从工厂中创建一个链接connection = connectionFactory.createConnection();//开启链接connection.start();//创建一个事务(这里通过参数可以设置事务的级别)session = connection.createSession(false,Session.AUTO_ACKNOWLEDGE);} catch (JMSException e) {e.printStackTrace();}}private static class Listener implements MessageListener{@Overridepublic void onMessage(Message arg0) {try {//获取监听到的消息并打印System.out.println("消息:"+((TextMessage)arg0).getText());} catch (JMSException e) {e.printStackTrace();}}}/* 获取生产者发过来的消息 */public void getMessage(String queueName){try {//创建一个队列Queue queue = session.createQueue(queueName);//消息消费者MessageConsumer consumer = session.createConsumer(queue);//监听生产者发送来的消息consumer.setMessageListener(new Listener());} catch (JMSException e) {e.printStackTrace();}}}

看了上面的列子,聪明的你是否已经会简单的应用activemq了呢?喜欢请关注小编哦!

你可能感兴趣的:(activemq,重启后java程序)