springboot--ActiveMQ--消息队列
ActiveMQ远程消息队列
一、我们创建springboot项目工程
二、创建完毕我们简单介绍 activeMQ
1.概述
消息中间件可以理解成就是一个服务软件,保存信息的容器,比如生活中的快递云柜.
我们把数据放到消息中间件当中, 然后通知对应的服务进行获取
消息中间件是在消息的传输过程中保存信息的容器
2.消息中间件应用场景
1. 使用消息服务器当做大的队列使用, 先进先出, 来处理高并发写入操作
2. 使用消息服务器可以将业务系统的串行执行改为并行执行, 处理效率高, 更合理的榨取服务器的性能.
3.同步与异步技术
同步技术
dubbo是一中同步技术, 实时性高, controller调用service项目, 调用就执行,
如果service项目中的代码没有执行完, controller里面的代码一致等待结果.
异步技术
mq消息中间件技术(jms) 是一种异步技术, 消息发送方, 将消息发送给消息服务器,
消息服务器未必立即处理.什么时候去处理, 主要看消息服务器是否繁忙,
消息进入服务器后会进入队列中, 先进先出.实时性不高.
三、JMS 介绍
概述:
jms的全称叫做Java message service (Java消息服务) jms是jdk底层定义的规范
各大厂商都是实现这个规范的技术
jms消息服务器同类型技术
1.ActiveMQ
是apache的一个比较老牌的消息中间件, 它比较均衡, 既不是最安全的, 也不是最快的.
2.RabbitMQ
是阿里巴巴的一个消息中间件, 更适合金融类业务, 它对数据的安全性比较高.能够保证数据不丢失.
3.Kafka
Apache下的一个子项目。特点:高吞吐,在一台普通的服务器上既可以达到10W/s的吞吐速率;适合处理海量数据。
JMS中支持的消息类型:
TextMessage
一个字符串对象
MapMessage
key-value
ObjectMessage
一个序列化的 Java 对象
BytesMessage
一个字节的数据流
StreamMessage
Java 原始值的数据流
JMS中的两种发送模式
1.点对点模式
一个发送方, 一个接收方. 也可以多个发送方, 一个接收方, 主要是接收方必须是第一个.
示例图
2.订阅发布模式
一个发送方, 多个接收方. 发送方也可以是多个, 主要看接收方, 接收方必须是多个
示例图
ActiveMQ服务器安装
官方网站: http:activemq.apache.org/
四、项目创建完毕后引入依赖
org.springframework.boot
spring-boot-starter-activemq org.apache.activemq
activemq-pool
5.15.0 org.springframework.boot
spring-boot-starter-web
写入yml配置
server:
port: 8080
spring:
activemq:
broker-url: tcp://www.yangbuyi.top:61616 # 可以使用我的服务器mq
user: admin
password: admin
close-timeout: 15s # 在考虑结束之前等待的时间
in-memory: true # 默认代理URL是否应该在内存中。如果指定了显式代理,则忽略此值。
non-blocking-redelivery: false # 是否在回滚回滚消息之前停止消息传递。这意味着当启用此命令时,消息顺序不会被保留。
send-timeout: 0 # 等待消息发送响应的时间。设置为0等待永远。
queue-name: active.queue # 点对点服务名称 可修改
topic-name: active.topic.name.model # 订阅服务名称 可修改
packages:
trust-all: true # 配置信任 反序列化对象要用到的 # packages:
# trust-all: true #不配置此项,会报错
pool:
enabled: true
max-connections: 10 #连接池最大连接数
idle-timeout: 30000 #空闲的连接过期时间,默认为30秒
消息配置类创建
package top.yangbuyi.config; import org.apache.activemq.ActiveMQConnectionFactory;
import org.apache.activemq.command.ActiveMQQueue;
import org.apache.activemq.command.ActiveMQTopic;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.jms.config.JmsListenerContainerFactory;
import org.springframework.jms.config.SimpleJmsListenerContainerFactory;
import org.springframework.jms.core.JmsMessagingTemplate; import javax.jms.ConnectionFactory;
import javax.jms.Queue;
import javax.jms.Topic; /**
* @description: 杨不易网站:www.yangbuyi.top
* @program: yangbuyi_mq
* @ClassName: BeanConfig
* @create: 2020-07-30 09:18
* @author: yangbuyi
* @since: JDK1.8
* @BeanConfig:
**/ @Configuration
public class BeanConfig { @Value("${spring.activemq.broker-url}")
private String brokerUrl; @Value("${spring.activemq.user}")
private String username; @Value("${spring.activemq.topic-name}")
private String password; @Value("${spring.activemq.queue-name}")
private String queueName; @Value("${spring.activemq.topic-name}")
private String topicName; @Bean(name = "queue")
public Queue queue() {
return new ActiveMQQueue(queueName);
} @Bean(name = "topic")
public Topic topic() {
return new ActiveMQTopic(topicName);
} /**
* @Description: 杨不易个人网址:http://yangbuyi.top
* 功能描述: 初始化工厂
* @Param:
* @return:
* @Author: TeouBle
* @Date: 2020/7/30 10:24
*/
@Bean
public ConnectionFactory connectionFactory() {
ActiveMQConnectionFactory activeMQConnectionFactory = new ActiveMQConnectionFactory(username, password, brokerUrl);
/* 配置信任 反序列化 */
activeMQConnectionFactory.setTrustAllPackages(true);
return activeMQConnectionFactory;
} /**
* @Description: 杨不易个人网址:http://yangbuyi.top
* 功能描述: JMS 模板 Java消息服务
* @Param:
* @return:
* @Author: TeouBle
* @Date: 2020/7/30 10:25
*/
@Bean
public JmsMessagingTemplate jmsMessageTemplate() {
return new JmsMessagingTemplate(connectionFactory());
} /**
* @Description: 杨不易个人网址:http://yangbuyi.top
* 功能描述: 在Queue模式中,对消息的监听需要对containerFactory进行配置
* @Param:
* @return:
* @Author: TeouBle
* @Date: 2020/7/30 10:25
*/
@Bean("queueListener")
public JmsListenerContainerFactory queueJmsListenerContainerFactory(ConnectionFactory connectionFactory) {
SimpleJmsListenerContainerFactory factory = new SimpleJmsListenerContainerFactory();
factory.setConnectionFactory(connectionFactory);
factory.setPubSubDomain(false);
return factory;
} /**
* @Description: 杨不易个人网址:http://yangbuyi.top
* 功能描述:在Topic模式中,对消息的监听需要对containerFactory进行配置
* @Param:
* @return:
* @Author: TeouBle
* @Date: 2020/7/30 10:25
*/
@Bean("topicListener")
public JmsListenerContainerFactory topicJmsListenerContainerFactory(ConnectionFactory connectionFactory) {
SimpleJmsListenerContainerFactory factory = new SimpleJmsListenerContainerFactory();
factory.setConnectionFactory(connectionFactory);
factory.setPubSubDomain(true);
return factory;
}
}
创建消息监听类
QueueConsumerListener 点对点模式 消费者 接收
package top.yangbuyi.listener; import lombok.extern.slf4j.Slf4j;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.jms.annotation.JmsListener;
import org.springframework.stereotype.Component;
import org.springframework.web.bind.annotation.RequestBody;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController; /**
* @description: 杨不易网站:www.yangbuyi.top
* @program: yangbuyi_mq
* @ClassName: QueueConsumerListener
* @create: 2020-07-30 09:21
* @author: yangbuyi
* @since: JDK1.8
* @QueueConsumerListener:
**/
@Component
@Slf4j
public class QueueConsumerListener {
@Value("${spring.activemq.queue-name}")
private String queueName; //queue模式的消费者
@JmsListener(destination = "${spring.activemq.queue-name}", containerFactory = "queueListener")
public void readActiveQueue(String message) {
System.out.println("queue接受到:" + message);
System.out.println("点对点服务名称:"+ queueName);
System.out.println("点对点监听成功");
} }
TopicConsumerListener 订阅模式 消费者 接收
package top.yangbuyi.listener; import lombok.extern.slf4j.Slf4j;
import org.apache.catalina.User;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.boot.configurationprocessor.json.JSONObject;
import org.springframework.jms.annotation.JmsListener;
import org.springframework.stereotype.Component;
import org.springframework.web.bind.annotation.RequestBody;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
import top.yangbuyi.controller.user; import javax.jms.JMSException;
import javax.jms.Message;
import javax.jms.ObjectMessage;
import java.io.Serializable;
import java.util.ArrayList;
import java.util.List; /**
* @description: 杨不易网站:www.yangbuyi.top
* @program: yangbuyi_mq
* @ClassName: TopicConsumerListener
* @create: 2020-07-30 09:23
* @author: yangbuyi
* @since: JDK1.8
* @TopicConsumerListener:
**/ @Component
public class TopicConsumerListener {
@Value("${spring.activemq.topic-name}")
private String topicName; //topic模式的消费者
@JmsListener(destination = "${spring.activemq.topic-name}", containerFactory = "topicListener")
public void readActiveQueue(Message message) {
ObjectMessage u = (ObjectMessage) message;
try {
user object = (user) u.getObject();
System.out.println(object.getName());
System.out.println(object.getAge());
} catch (JMSException e) {
e.printStackTrace();
}
System.out.println();
System.out.println("topic接受到:" + message);
System.out.println("订阅服务名称:" + topicName);
}
}
创建一个小对象用来测试传递对象
package top.yangbuyi.controller; import java.io.Serializable; /**
* @description: 杨不易网站:www.yangbuyi.top
* @program: yangbuyi_mq
* @ClassName: user
* @create: 2020-07-30 10:03
* @author: yangbuyi
* @since: JDK1.8
* @user:
**/ public class user implements Serializable {
private String name;
private Integer age; public user(String name, Integer age) {
this.name = name;
this.age = age;
} public String getName() {
return name;
} public void setName(String name) {
this.name = name;
} public Integer getAge() {
return age;
} public void setAge(Integer age) {
this.age = age;
}
}
创建controller
package top.yangbuyi.controller; import javafx.geometry.Pos;
import lombok.extern.slf4j.Slf4j;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.http.MediaType;
import org.springframework.jms.core.JmsMessagingTemplate;
import org.springframework.web.bind.annotation.*; import javax.jms.Destination;
import javax.jms.Queue;
import javax.jms.Topic;
import java.util.ArrayList; /**
* @description: 杨不易网站:www.yangbuyi.top
* @program: yangbuyi_mq
* @ClassName: ProducerController
* @create: 2020-07-30 09:20
* @author: yangbuyi
* @since: JDK1.8
* @ProducerController: 生产者
**/ @RestController
@Slf4j
public class ProducerController {
@Autowired
private JmsMessagingTemplate jmsMessagingTemplate; @Autowired
private Queue queue; @Autowired
private Topic topic; @RequestMapping(value ="queue/test",method = RequestMethod.POST)
public String sendQueue(@RequestBody String str) {
this.sendMessage(this.queue, str);
return "success---点对点发送成功";
} @RequestMapping(value = "topic/test",method = RequestMethod.POST)
public String sendTopic(@RequestBody String str) {
this.sendMessageObject(this.topic, new user(str,10));
return "success---订阅发送成功";
} // 发送消息,destination是发送到的队列,message是待发送的消息
// 生产者
private void sendMessageObject(Destination destination, final Object message){
jmsMessagingTemplate.convertAndSend(destination, message); } // 发送消息,destination是发送到的队列,message是待发送的消息
// 生产者
private void sendMessage(Destination destination, final String message){
jmsMessagingTemplate.convertAndSend(destination, message);
} }
五、进行postman发送请求
订阅服务
点对点服务
到此activemq就讲到这里了 还有蛮多可以自己去 学习学习!!!
你的压力来源于无法自律,只是假装努力,现状跟不上内心欲望,所以你焦虑又恐慌。——杨不易
springboot--ActiveMQ--消息队列的更多相关文章
- SpringBoot集成ActiveMq消息队列实现即时和延迟处理
原文链接:https://blog.csdn.net/My_harbor/article/details/81328727 一.安装ActiveMq 具体安装步骤:自己谷歌去 二.新建springbo ...
- activemq消息队列的使用及应用docker部署常见问题及注意事项
activemq消息队列的使用及应用docker部署常见问题及注意事项 docker用https://hub.docker.com/r/rmohr/activemq/配置在/data/docker/a ...
- JAVA的设计模式之观察者模式----结合ActiveMQ消息队列说明
1----------------------观察者模式------------------------------ 观察者模式:定义对象间一对多的依赖关系,当一个对象的状态发生改变时,所有依赖于它的 ...
- ActiveMQ消息队列从入门到实践(4)—使用Spring JMS收发消息
Java消息服务(Java Message Service ,JMS)是一个Java标准,定义了使用消息代理的通用API .在JMS出现之前,每个消息代理都有私有的API,这就使得不同代理之间的消息代 ...
- C#实现ActiveMQ消息队列
本文使用C#实现ActiveMQ消息队列功能. 一.首先需要导入两个包,分别是:Apache.NMS 和 Apache.NMS.ActiveMQ 二.创建Winform程序实现生产者功能. 三.Pro ...
- ActiveMQ 消息队列服务
1 ActiveMQ简介 1.1 ActiveMQ是什么 ActiveMQ是一个消息队列应用服务器(推送服务器).支持JMS规范. 1.1.1 JMS概述 全称:Java Message Serv ...
- ActiveMQ基础教程(四):.net core集成使用ActiveMQ消息队列
接上一篇:ActiveMQ基础教程(三):C#连接使用ActiveMQ消息队列 这里继续说下.net core集成使用ActiveMQ.因为代码比较多,所以放到gitee上:https://gitee ...
- SpringBoot学习笔记(11)-----SpringBoot中使用rabbitmq,activemq消息队列和rest服务的调用
1. activemq 首先引入依赖 pom.xml文件 <dependency> <groupId>org.springframework.boot</groupId& ...
- SpringBoot中使用rabbitmq,activemq消息队列和rest服务的调用
1. activemq 首先引入依赖 pom.xml文件 <dependency> <groupId>org.springframework.boot</groupId& ...
- springboot中activeMQ消息队列的引入与使用(发送短信)
1.引入pom依赖 <!--activemq--><dependency> <groupId>org.springframework.boot</groupI ...
随机推荐
- 使用C#发送邮件支持 Implicit SSL
安装Package: Install-Package AIM 使用下面的代码发送: class Mail { private static string mailAddress = "{yo ...
- 图解 LeetCode 算法汇总——双指针
双指针算法是一种比较常用于搜索链表或数组相关的问题,很多算法的基本的解题思路就是使用暴力搜索法.而双指针是对暴力搜索的一种优化,通过双指针可以减少数据的遍历次数.通常双指针是有两个指针,叫做 ligh ...
- Vue-基本语法及事件绑定
一.基本语法 v-bind绑定: 双大括号不能在 HTML attributes 中使用.想要响应式地绑定一个 attribute,应该使用 v-bind 指令 代码展示: <div id=&q ...
- 【Python】代理池针对ip拦截破解
代理池是一种常见的反反爬虫技术,通过维护一组可用的代理服务器,来在被反爬虫限制的情况下,实现数据的爬取.但是,代理池本身也面临着被目标网站针对ip进行拦截的风险. 本文将详细介绍代理池针对ip拦截破解 ...
- Vite+ts+springboot项目集成2
项目集成 集成element-plus 官网地址: 安装图标库 pnpm install element-plus @element-plus/icons-vue 入口文件main.ts全局安装ele ...
- 噢耶!字节后端Offer,拿到了
很多同学反馈多搞点面经,说来就来! 今天分享一位拿到字节跳动实习Offer的面经,没错,Java转Go. 别问我选Java还是选Go,成年人不做选择题.先搞定一个语言,再学第二语言从来不是难事. 无论 ...
- CCF PTA编程培训师资认证
考试费用: 双会员500元,任意一方单会员750元,报名考试同时成为CCF专业会员850元,非会员1000元. P/T2补考费用:双会员200元,任意一方单会员300元,非会员400元. T1补考费用 ...
- 聊聊Maven的依赖传递、依赖管理、依赖作用域
1. 依赖传递 在Maven中,依赖是会传递的,假如在业务项目中引入了spring-boot-starter-web依赖: <dependency> <groupId>org. ...
- Subtree 题解
Subtree 题目大意 给定一颗树,你可以选出一些节点,你需要对于每个点求出在强制选这个点的情况下所有选择的点联通的方案数,对给定模数取模. 思路分析 对于这种求树上每一个点方案数的题目,首先考虑换 ...
- 使用VSCode新建解决方案,添加ClassLib类库工程
最近准备全面转向VSCode开发C#代码,所以第一件事就是使用VSCode新建解决方案,添加工程. 通过ChatGPT找到的大致的实现方案: 首先,打开VS Code的终端,然后导航到您想要创建解决方 ...