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--消息队列的更多相关文章

  1. SpringBoot集成ActiveMq消息队列实现即时和延迟处理

    原文链接:https://blog.csdn.net/My_harbor/article/details/81328727 一.安装ActiveMq 具体安装步骤:自己谷歌去 二.新建springbo ...

  2. activemq消息队列的使用及应用docker部署常见问题及注意事项

    activemq消息队列的使用及应用docker部署常见问题及注意事项 docker用https://hub.docker.com/r/rmohr/activemq/配置在/data/docker/a ...

  3. JAVA的设计模式之观察者模式----结合ActiveMQ消息队列说明

    1----------------------观察者模式------------------------------ 观察者模式:定义对象间一对多的依赖关系,当一个对象的状态发生改变时,所有依赖于它的 ...

  4. ActiveMQ消息队列从入门到实践(4)—使用Spring JMS收发消息

    Java消息服务(Java Message Service ,JMS)是一个Java标准,定义了使用消息代理的通用API .在JMS出现之前,每个消息代理都有私有的API,这就使得不同代理之间的消息代 ...

  5. C#实现ActiveMQ消息队列

    本文使用C#实现ActiveMQ消息队列功能. 一.首先需要导入两个包,分别是:Apache.NMS 和 Apache.NMS.ActiveMQ 二.创建Winform程序实现生产者功能. 三.Pro ...

  6. ActiveMQ 消息队列服务

      1 ActiveMQ简介 1.1 ActiveMQ是什么 ActiveMQ是一个消息队列应用服务器(推送服务器).支持JMS规范. 1.1.1 JMS概述 全称:Java Message Serv ...

  7. ActiveMQ基础教程(四):.net core集成使用ActiveMQ消息队列

    接上一篇:ActiveMQ基础教程(三):C#连接使用ActiveMQ消息队列 这里继续说下.net core集成使用ActiveMQ.因为代码比较多,所以放到gitee上:https://gitee ...

  8. SpringBoot学习笔记(11)-----SpringBoot中使用rabbitmq,activemq消息队列和rest服务的调用

    1. activemq 首先引入依赖 pom.xml文件 <dependency> <groupId>org.springframework.boot</groupId& ...

  9. SpringBoot中使用rabbitmq,activemq消息队列和rest服务的调用

    1. activemq 首先引入依赖 pom.xml文件 <dependency> <groupId>org.springframework.boot</groupId& ...

  10. springboot中activeMQ消息队列的引入与使用(发送短信)

    1.引入pom依赖 <!--activemq--><dependency> <groupId>org.springframework.boot</groupI ...

随机推荐

  1. 6-MySQL查询条件

    在MySQL中,高级查询是指使用更复杂的查询语句和操作符来检索和操作数据库中的数据.高级查询可以帮助您更精确地找到所需的信息,并提高查询的效率和灵活性. 以下是高级查询的一些常见应用场景和意义: 连接 ...

  2. E-GraphSAGE: A Graph Neural Network based Intrusion Detection System 笔记

    E-GraphSAGE: A Graph Neural Network based Intrusion Detection System 目录 E-GraphSAGE: A Graph Neural ...

  3. 文心一言 VS 讯飞星火 VS chatgpt (100)-- 算法导论9.3 6题

    六.用go语言,对一个包含n个元素的集合来说,k分位数是指能把有序集合分成k个等大小集合的第k-1个顺序统计量.给出一个能找出某一集合的k分位数的 O(nlgk)时间的算法. 文心一言: 要找到一个集 ...

  4. mooc第五单元《管理组织》单元测试

    第五单元<管理组织>单元测试     返回 本次得分为:30.00/50.00, 本次测试的提交时间为:2020-08-30, 如果你认为本次测试成绩不理想,你可以选择 再做一次 . 1 ...

  5. wps 设置 word文档不可被修改,指定区域可以修改

    wps 设置 word文档不可被修改,指定区域可以修改 2021年03月03日09:38:10

  6. 9. 用Rust手把手编写一个wmproxy(代理,内网穿透等), HTTP2改造篇之HPACK示例, 了解http2头信息如何处理

    9. 用Rust手把手编写一个wmproxy(代理,内网穿透等), HTTP2改造篇之HPACK示例, 了解http2头信息如何处理 项目 ++wmproxy++ gite: https://gite ...

  7. unity利用Rigibody实现第一人称移动

    1. CameraRotation脚本,将它给MainCamera,实现上下视角旋转 using System.Collections; using System.Collections.Generi ...

  8. .NET周刊【10月第3期 2023-10-22】

    国内文章 .NET 8 RC 2 发布,将在11月14日发布正式版 https://www.cnblogs.com/shanyou/p/17756172.html 微软于2023年10月10日发布了. ...

  9. P9481 [NOI2023] 贸易 题解

    题目链接 题目要求我们求出任意两点间最短路径之和,由于图比较特殊,除树边外只有祖先到其子树内的边,我们首先考虑最短路径有没有什么特殊性质. 注意到两点之间的最短路分为一下三种: 节点到其祖先的最短路: ...

  10. IDEA在Debug模式下修改Java类,不小心关闭 Reload Changed Classes for AppArrowWebApplication 框提示之后的处理

    问题描述:Springboot maven 聚合项目里面,经常要启动多个服务. 当我们修改其中一个服务的时候,debug 启动时 idea 就会提示是否需要重新编译修改的内容,弹窗让你选择reload ...