ActiveMQ 基础
Apache ActiveMQ是Apache软件基金会所研发的开放源代码消息中间件;由于ActiveMQ是一个纯Java程序,因此只需要操作系统支持Java虚拟机,ActiveMQ便可执行。它能很好地支持J2EE提出的JMS(Java Message Service,即Java消息服务)规范。
端口
ActiveMQ默认配置下启动会启动8161和61616两个端口,其中8161是mq自带的管理后台的端口,61616是mq服务默认端口 。
8161是后台管理系统,61616是给java用的tcp端口
依赖
<dependency>
<groupId>org.apache.activemq</groupId>
<artifactId>activemq-all</artifactId>
<version>RELEASE</version>
</dependency>
队列
- 当一个消息进入队列,进入队列的消息是1,等待消费的消息是1
- 当消息消费后,进入队列的消息是1,等待消费的消息是0,出队列的消息是1
- 再来一条消息,进入队列的消息是2,等待消费的消息是1
生产者
import org.apache.activemq.ActiveMQConnectionFactory;
import javax.jms.*;
public class JmsProduce {
private static final String ACTIICEMQ_URL = "tcp://192.168.211.128:61616";
public static void main(String[] args) throws JMSException {
//创建连接工厂
ActiveMQConnectionFactory activeMQConnectionFactory = new ActiveMQConnectionFactory(ACTIICEMQ_URL);
//获取连接
Connection connection = activeMQConnectionFactory.createConnection();
connection.start();
//创建会话session(第一个参数是事务,第二个参数是(自动)签收)
Session session = connection.createSession(false, Session.AUTO_ACKNOWLEDGE);
/**
* Queue:队列
* “负载均衡”模式,平均交替分配(1.3.5 / 2.4.6)
* 如果当前没有消费者,消息不会丢失,消费者上线后,继续发送
* 一条消息只会发送给一个消费者
*/
//创建目的地
Queue queue = session.createQueue("name1");
//创建消息生产者
MessageProducer producer1 = session.createProducer(queue);
//通过消息生产者发送消息到mq队列
for (int i = 1; i <=3; i++) {
//创建消息
TextMessage textMessage = session.createTextMessage("Queue---" + i);
//通过消息生产者发送消息
producer1.send(textMessage);
}
producer1.close();
/**
* Topic:主题(发布)
* 消费者必须在线
* 如果没有消费者,消息会丢失
* 消费者多,性能会降低
*/
//创建目的地
Topic topic = session.createTopic("name2");
//创建消息生产者
MessageProducer producer2 = session.createProducer(topic);
//通过消息生产者发送消息到mq队列
for (int i = 1; i <=3; i++) {
//创建消息
TextMessage textMessage = session.createTextMessage("Topic---" + i);
//通过消息生产者发送消息
producer2.send(textMessage);
}
//关闭资源
producer2.close();
session.close();
connection.close();
}
}
生产者持久化
持久化传输:消息会先保存到磁盘中,然后再转发给订阅者,即“储存转发”。
非持久化传输:消息会保存到内存中
Queue:队列(默认就是持久化,不必设置)
持久化:messageProducer.setDeliveryDode(DeliveryMode.PERSISTENT)
Topic:主题(发布)
订阅者不需一直在线,不在线,消息可以在上线时重新派发:
messageProducer.setDeliveryMode(DeliveryMode.PERSISTENT); //持久化
connection.start(); //连接MQ服务器(放在 durableSubscriber 后面)
消费者
import org.apache.activemq.ActiveMQConnectionFactory;
import javax.jms.*;
import java.io.IOException;
public class JmsConsumer {
private static final String ACTIICEMQ_URL = "tcp://192.168.211.128:61616";
public static void main(String[] args) throws JMSException, IOException {
//创建连接工厂
ActiveMQConnectionFactory activeMQConnectionFactory = new ActiveMQConnectionFactory(ACTIICEMQ_URL);
//获取连接
Connection connection = activeMQConnectionFactory.createConnection();
connection.start();
//创建会话session
Session session = connection.createSession(false, Session.AUTO_ACKNOWLEDGE);
/**
* Query:队列
* 如果有多个消费者消费同一个消息生产者:平均交替分配(1.3.5/2.4.6)
*/
//创建目的地
Queue queue = session.createQueue("name1");
//创建消费者
MessageConsumer consumer1 = session.createConsumer(queue);
/**
* receive()获取消息(同步阻塞)
*/
while (true){
//不加参数,一直等着
//加参数,过时不候
TextMessage receive = (TextMessage) consumer1.receive(4000l);
if(null != receive){
System.out.println(receive.getText());
}else {
break;
}
}
consumer1.close();
/**
* 通过监听方式获取消息(异步)
* 当消息到达后,自动调用onMessage(Message message)方法
*/
consumer1.setMessageListener(new MessageListener() {
public void onMessage(Message message) {
if (null != message && message instanceof TextMessage) {
TextMessage textMessage = (TextMessage) message;
try {
System.out.println("消息监听器:" + textMessage.getText());
} catch (JMSException e) {
e.printStackTrace();
}
}
}
});
//保证控制台不关(不加此句,还未消费程序就结束了)
System.in.read();
consumer1.close();
/**
* Topic:主题(消费)
* 接收者必须在线
* 先启动接收,再启动生产,不然发布的消息就是废消息
*/
Topic topic = session.createTopic("name2");
//创建消费者
MessageConsumer consumer2 = session.createConsumer(topic);
consumer2.setMessageListener(new MessageListener() {
public void onMessage(Message message) {
if (null != message && message instanceof TextMessage) {
TextMessage textMessage = (TextMessage) message;
try {
System.out.println("消息监听器:" + textMessage.getText());
} catch (JMSException e) {
e.printStackTrace();
}
}
}
});
//保证控制台不关(不加此句,还未消费就关了)
System.in.read();
//关闭资源
consumer2.close();
session.close();
connection.close();
}
}
消费者持久化(订阅)
Topic:主题(订阅)
订阅者不需一直在线,不在线,消息可以在上线时重新派发:
connection.setClientID("ld"); //向MQ注册成为订阅者(注册后,下线后再上线仍可以收到)
Session session = connection.createSession(false, Session.AUTO_ACKNOWLEDGE);
Topic topic = session.createTopic("name2");
TopicSubscriber durableSubscriber =
session.createDurableSubscriber(topic, "topic2"); //创建持久化订阅,订阅的主题:Topic
connection.start(); //连接MQ服务器(放在 durableSubscriber 后面)
Message message = durableSubscriber.receive(); //订阅者接收主题
事务与签收
PERSISTENT:持久性
- 持久:服务器宕机,数据存在(默认)
- 非持久:服务器宕机,数据不存在事务:
connection.createSession(false, Session.AUTO_ACKNOWLEDGE);
- 如果是true,开启事务,生产者需要先执行send,再执行commit,消息才会正真提交到队列中
- 消费者开启事务,如果事务回滚或者未提交,会再次接收到消息签收(Acknowledge):
connection.createSession(false, Session.AUTO_ACKNOWLEDGE);
- 默认自动签收:Session.AUTO_ACKNOWLEDGE
- 手动签收需要反馈:message.acknowledge();
- 有事务的签收:自动手动一样,没有区别,但是必须comment()提交

ActiveMQ 基础的更多相关文章
- ActiveMQ基础教程----简单介绍与基础使用
概述 ActiveMQ是由Apache出品的,一款最流行的,能力强劲的开源消息总线.ActiveMQ是一个完全支持JMS1.1和J2EE 1.4规范的 JMS Provider实现,它非常快速,支持多 ...
- ActiveMQ基础使用
概述 ActiveMQ是由Apache出品的,一款最流行的,能力强劲的开源消息总线.ActiveMQ是一个完全支持JMS1.1和J2EE 1.4规范的 JMS Provider实现,它非常快速,支持多 ...
- ActiveMQ基础教程(四):.net core集成使用ActiveMQ消息队列
接上一篇:ActiveMQ基础教程(三):C#连接使用ActiveMQ消息队列 这里继续说下.net core集成使用ActiveMQ.因为代码比较多,所以放到gitee上:https://gitee ...
- ActiveMQ基础教程(三):C#连接使用ActiveMQ消息队列
接上一篇:ActiveMQ基础教程(二):安装与配置(单机与集群) 安装部署好集群环境:192.168.209.133:61616,192.168.209.134:61616,192.168.209. ...
- 成小胖学习ActiveMQ·基础篇
过了个春节,回到公司的成小胖变成了成大胖.但是你们千万别以为他那个大肚子里面装的都是肥肉,里面的墨水也多了不少嘞,毕竟成小胖利用春节的半个月时间专心学习并研究了 ActiveMQ,嘿嘿……这不,为了检 ...
- ActiveMQ基础教程(二):安装与配置(单机与集群)
因为本文会用到集群介绍,因此准备了三台虚拟机(当然读者也可以使用一个虚拟机,然后使用不同的端口来模拟实现伪集群): 192.168.209.133 test1 192.168.209.134 test ...
- ActiveMQ基础教程(一):认识ActiveMQ
ActiveMQ是Apache软件基金会所研发开源的消息中间件,为应用程序提供高效的.可扩展的.稳定的和安全的企业级消息通信. 现在的消息队列有不少,RabbitMQ.Kafka.RocketMQ,Z ...
- ActiveMQ基础
消息队列的作用 为什么使用ActiveMQ,不使用其他工具 下载安装包并启动 http://localhost:8161/admin/ (账号:admin:admin) Java实现步骤: // 1. ...
- ActiveMQ基础简介
1. 什么是ActiveMQ ActiveMQ 是Apache出品,最流行的,能力强劲的开源消息总线.ActiveMQ 是一个完全支持JMS1.1和J2EE 1.4规范的 JMS Provider实现 ...
- ActiveMQ基础01——Linux下载安装ActiveMQ
1.下载 下载地址:http://activemq.apache.org/ 点击按钮 下载Linux下最新版安装包,点击即可下载 2.安装ActiveMQ 将之前下载的安装包上传到linux当中,一般 ...
随机推荐
- 细数Intellij Idea10个蛋疼问题!
Intellij Idea以下简称IJ. 昨天细数了IJ上的10大666的姿势,IJ确实很智能,在很多方便可以完爆Eclipes,可在某些方面真的被Eclipse秒杀 1.乱码 在Eclipse中很少 ...
- USACO2008 Time Management /// 贪心 oj24386
题目大意: 有N个工作被编号为1..N (1 ≤ N ≤ 1,000) 完成第i个工作需要T_i (1 ≤ T_i ≤ 1,000)的时间 第i个工作需在S_i (1 ≤ S_i ≤ 1,000,00 ...
- vue echarts 给饼图中间添加文字 ,并且添加多个样式
最近根据设计要求写了一个统计图,以下是设计要求,要求中间文字分别是总数和汉字,样式分别不同 好吧具体的解决方案如下 方案一 series: [ { type:'pie', radius: ['50%' ...
- go 数据类型和操作符
文件名&关键字&标识符 1. 所有go源码以 .go结尾 2. 标识符以字母或者下划线开头,大小写敏感:add, Add, _add _是特殊标识符,用来忽略结果 3. 保留关键字 G ...
- 2019-9-11-在-P2P-文件分享应用以文件或文件段为单位的优缺
title author date CreateTime categories 在 P2P 文件分享应用以文件或文件段为单位的优缺 lindexi 2019-09-11 10:23:27 +0800 ...
- Cats Transport
Cats Transport 现在有n座山,第i座山的坐标为\(d_i\),初始p个饲养员在山1,有m只猫,每只猫有一个属性\(h_i,t_i\)表示猫i 在\(h_i\)以及它在\(t_i\)时间后 ...
- 页面JS缓存问题解决方案
.在jsp中加入头 <META HTTP-EQUIV="Pragma" CONTENT="no-cache"> <META HTTP-EQUI ...
- golang中使用gorm连接mysql操作
一.代码 package main import ( "fmt" "github.com/jinzhu/gorm" _ "github.com/go- ...
- MailHelper
using System; using System.Collections.Concurrent; using System.Collections.Generic; using System.Co ...
- MDK(KEIL)使用Astyle格式化代码
关于Astyle Astyle 的全称是Artistic Style的简称,是一个开源的源代码格式化工具,可以对C,C++,C#以及Java等编程语言的源代码进行缩进.格式化.美化. Home Pag ...