热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

SpringBoot企业级开发(三)异步消息

异步消息异步消息主要目的是为了系统与系统之间的通信。所谓异步消息即消息发送者无须等待消息接收者的处理及返回,甚至无须关心消息是否发送成功。在异步消息中有两个很重要的
异步消息

异步消息主要目的是为了系统与系统之间的通信。所谓异步消息即消息发送者无须等待消息接收者的处理及返回,甚至无须关心消息是否发送成功。
在异步消息中有两个很重要的概念,即消息代理和目的地。当消息发送者发送消息后,消息将由消息代理接管,消息代理保证消息传递到指定的目的地。
异步消息主要有两种形式的目的地:队列(queue)和主题(topic)。队列用于点对点式的消息通信;主题用于发布/订阅式的消息通信。

1:点对点式

当消息发送者发送消息,消息代理获得消息后将消息放进一个队列(queue)里,当有消息接收者来接收消息的时候,消息将从队列里取出来传递给接收者,这时候队列里 就没有了这条消息。
点对点式确保的是每一条消息只有唯一的发送者和接收者,但这并不能说明只有一个接收者可以从队列里接收消息。因为队列里有多个消息,点对点式只保证每一条消息只有唯一的发送者和接收者。

2:发布/订阅式

和点对点不同,发布/订阅式是消息发送者发送消息到主题(topic),而多个消息接收者监听这个主题。此时的消息发送者和接收者分别叫做发布者和订阅者。

消息代理

1:JMS(Java Message Service)

JMS即Java消息服务,是基于JVM消息代理的规范。而ActiveMQ、HornetQ是一个JMS消息代理的实现;

2:AMQP(Advanced Message Queuing Protocol)

AMQP也是一个消息代理的规范,但它不仅兼容JMS,还支持跨语言和平台。AMQP的主要实现有RabbitMQ;

JMS实战

1:新建Spring Boot项目,依赖无;虽然Spring Boot提供了JMS的依赖,但默认使用的消息代理是HornetQ,本例使用的是ActiveMQ,所以我们需要添加spring-jms和activemq-client的依赖:

org.springframeworkspring-jmsorg.apache.activemqactivemq-client

2:配置属性
application.properties

spring.activemq.broker-url=tcp://localhost:61616 //消息代理的地址

3:消息定义

//定义JMS发送的消息需实现MessageCreator接口,并重写createMessage方法
public class Msg implements MessageCreator{@Overridepublic Message createMessage(Session session) throws JMSException {return session.createTextMessage("测试消息");}}

4:消息发送及目的地的定义

@SpringBootApplication
//Spring Boot提供了CommandLineRunner接口,用于程序启动后执行的代码,通过重写其run方法执行
public class ActiveMqApplication implements CommandLineRunner{ @AutowiredJmsTemplate jmsTemplate; //注入Spring Boot为我们配置好的JmsTemplate的Beanpublic static void main(String[] args) {SpringApplication.run(ActiveMqApplication.class, args);}@Overridepublic void run(String... args) throws Exception {//通过JmsTemplate的send方法向my-destination目的地发送Msg的消息,这里也等于在消息代理上定义了一个目的地叫my-destination。jmsTemplate.send("my-destination", new Msg()); }
}

5:消息监听

@Component
public class Receiver {//&#64;JmsListener用来简化JMS开发&#xff0c;destination属性指定要监听的目的地&#xff0c;即可接收该目的地发送的消息。此例监听my-destination目的地发送的消息&#64;JmsListener(destination &#61; "my-destination") public void receiveMessage(String message) {System.out.println("接受到: <" &#43; message &#43; ">");}}

运行测试&#xff1a;
启动程序&#xff0c;程序会自动向目的地my-destination发送消息&#xff0c;而Receiver类注解了&#64;JmsListener的方法会自动监听my-destination发送的消息。
这里写图片描述
在ActiveMQ的管理页面可以查看我们目的地的相关信息&#xff1a;
这里写图片描述

参考书籍&#xff1a;Spring Boot实战&#xff1b;
以上只是学习所做的笔记&#xff0c;以供日后参考&#xff01;&#xff01;&#xff01;


推荐阅读
  • 深入解析Spring框架中的双亲委派机制突破方法
    在探讨Spring框架中突破双亲委派机制的方法之前,首先需要了解类加载器的基本概念。类加载器负责将类的全限定名转换为对应的二进制字节流。每个类在被特定的类加载器加载后,其唯一性得到保证。然而,这种机制在某些场景下可能会限制灵活性,因此Spring框架提供了一些策略来突破这一限制,以实现更加动态和灵活的类加载。这些策略不仅能够提升系统的可扩展性,还能在复杂的运行环境中确保类的正确加载和管理。 ... [详细]
  • Spring框架入门指南:专为新手打造的详细学习笔记
    Spring框架是Java Web开发中广泛应用的轻量级应用框架,以其卓越的功能和出色的性能赢得了广大开发者的青睐。本文为初学者提供了详尽的学习指南,涵盖基础概念、核心组件及实际应用案例,帮助新手快速掌握Spring框架的核心技术与实践技巧。 ... [详细]
  • 深入解析Tomcat:开发者的实用指南
    深入解析Tomcat:开发者的实用指南 ... [详细]
  • 本文提供了 RabbitMQ 3.7 的快速上手指南,详细介绍了环境搭建、生产者和消费者的配置与使用。通过官方教程的指引,读者可以轻松完成初步测试和实践,快速掌握 RabbitMQ 的核心功能和基本操作。 ... [详细]
  • 本课程详细解析了Spring AOP的核心概念及其增强机制,涵盖前置增强、后置增强和环绕增强等类型。通过具体示例,深入探讨了如何在实际开发中有效运用这些增强技术,以提升代码的模块化和可维护性。此外,还介绍了Spring AOP在异常处理和性能监控等场景中的应用,帮助开发者更好地理解和掌握这一强大工具。 ... [详细]
  • Ceph API微服务实现RBD块设备的高效创建与安全删除
    本文旨在实现Ceph块存储中RBD块设备的高效创建与安全删除功能。开发环境为CentOS 7,使用 IntelliJ IDEA 进行开发。首先介绍了 librbd 的基本概念及其在 Ceph 中的作用,随后详细描述了项目 Gradle 配置的优化过程,确保了开发环境的稳定性和兼容性。通过这一系列步骤,我们成功实现了 RBD 块设备的快速创建与安全删除,提升了系统的整体性能和可靠性。 ... [详细]
  • 如何在Java中高效构建WebService
    本文介绍了如何利用XFire框架在Java中高效构建WebService。XFire是一个轻量级、高性能的Java SOAP框架,能够简化WebService的开发流程。通过结合MyEclipse集成开发环境,开发者可以更便捷地进行项目配置和代码编写,从而提高开发效率。此外,文章还详细探讨了XFire的关键特性和最佳实践,为读者提供了实用的参考。 ... [详细]
  • 2019年后蚂蚁集团与拼多多面试经验详述与深度剖析
    2019年后蚂蚁集团与拼多多面试经验详述与深度剖析 ... [详细]
  • 在Spring框架中,基于Schema的异常通知与环绕通知的实现方法具有重要的实践价值。首先,对于异常通知,需要创建一个实现ThrowsAdvice接口的通知类。尽管ThrowsAdvice接口本身不包含任何方法,但开发者需自定义方法来处理异常情况。此外,环绕通知则通过实现MethodInterceptor接口来实现,允许在方法调用前后执行特定逻辑,从而增强功能或进行必要的控制。这两种通知机制的结合使用,能够有效提升应用程序的健壮性和灵活性。 ... [详细]
  • 本文将介绍一种扩展的ASP.NET MVC三层架构框架,并通过使用StructureMap实现依赖注入,以降低代码间的耦合度。该方法不仅能够提高代码的可维护性和可测试性,还能增强系统的灵活性和扩展性。通过具体实践案例,详细阐述了如何在实际开发中有效应用这一技术。 ... [详细]
  • 本文深入探讨了 `ExpressionChangedAfterItHasBeenCheckedError` 错误的原因及其解决方案。通过分析 Angular 的变更检测机制,详细解释了该错误的发生条件,并提供了多种有效的应对策略,帮助开发者在实际开发中避免这一常见问题。 ... [详细]
  • Spring注解开发指南:@Resource与@Component详解 ... [详细]
  • 在启用分层编译的情况下,即时编译器(JIT)的触发条件涉及多个因素,包括方法调用频率、代码复杂度和运行时性能数据。本文将详细解析这些条件,并探讨分层编译如何优化JVM的执行效率。 ... [详细]
  • 本文深入探讨了Java枚举类型的使用与实践,详细解析了枚举的基本用法及其在实际开发中的应用。首先介绍了枚举作为常量的替代方案,自JDK 1.5起,通过枚举可以更加简洁、安全地定义常量,避免了传统方式中可能出现的错误。此外,文章还探讨了枚举在实现单例模式、状态机等场景中的优势,并提供了多个实际案例,帮助开发者更好地理解和运用这一强大的语言特性。 ... [详细]
  • MVVM架构~mvc,mvp,mvvm大话开篇
    返回目录百度百科的定义:MVP是从经典的模式MVC演变而来,它们的基本思想有相通的地方:ControllerPresenter负责逻辑的处理,Model提供数据,View负责显示。作为一种新的模 ... [详细]
author-avatar
书友42218068
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有