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

常见的消息队列

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

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

c1a5e12e7c59c5a229cb123da3f4faaf.png

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了呢?喜欢请关注小编哦!

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值