SpringBoot 事件监听处理(五十一)

news2025/1/13 9:33:16

当死亡笼罩在脑海,请用生的信念打败它

上一章简单介绍了Retry重试机制(五十), 如果没有看过,请观看上一章

参考文章: https://blog.csdn.net/qq_37758497/article/details/118863308

一. Spring 事件监听

Spring的事件监听(也叫事件驱动)是观察者模式的一种实现,只要是观察者模式,就含有主题(针对该主题的事件),发布者(发布主题或事件),

订阅者(监听主题的人)。有三个部分组成,事件(ApplicationEvent)、监听器(ApplicationListener)和事件发布操作

作用:

使用事件机制我们可以将相互耦合的代码解耦,从而方便功能拓展和调整。

image-20230609090902855

关于观察者的用法, 可以看老蝴蝶写的 设计模式 系列文章

二. Spring 事件监听

二.一 依赖处理

SpringBoot 相应的依赖已经包含 context 依赖了, 不需要在 pom.xml 文件中单独添加。

image-20230609091205783

二.二 定义事件实体, 继承 ApplicationEvent

如定义一个订单 Order 事件, 里面有一个 message 属性

/**
 * 事件
 *
 * @author yuejianli
 * @date 2022-08-22
 */
public class OrderEvent extends ApplicationEvent {
	private String message;
	
	public OrderEvent(Object source, String message) {
		super(source);
		this.message = message;
	}
	
	public OrderEvent(Object source) {
		super(source);
	}
	
	public String getMessage() {
		return message;
	}
}

二.三 定义一个事件监听, 实现 ApplicationListener 接口

@Slf4j
@Component
public class OrderListener implements ApplicationListener<OrderEvent> {
	
	@Override
	public void onApplicationEvent(OrderEvent event) {
		//执行操作
		log.info(">>> 执行事件监听开始,调用参数是:{}", event.getMessage());
		try {
			//执行具体的业务处理逻辑
			TimeUnit.SECONDS.sleep(3);
            log.info(">>> 执行具体的任务完成");
		} catch (Exception e) {
			e.printStackTrace();
		}
		log.info(">>>>>>执行事件监听结束");
	}
}

二.四 发布任务处理

通过 ApplicationContext .publishEvent 发布任务

@Service
@Slf4j
public class OrderEventService {
	
	@Resource
	private ApplicationContext applicationContext;
	
	/**
	 * 处理事件
	 */
	public void handlerOrder(String message) {
		log.info(">>>>开始处理订单,订单信息是:{}", message);
		applicationContext.publishEvent(new OrderEvent(this, message));
		log.info(">>>> 调用订单程序成功,任务结束");
	}
}

二.五 测试验证

@SpringBootTest
@RunWith(SpringRunner.class)
public class OrderEventTest {
	@Resource
	private OrderEventService orderEventService;
	@Test
	public void syncTest() {
		orderEventService.handlerOrder("岳泽霖购买护肤品");
	}
}

查看控制台, 会发现,事件发布是成功的.

image-20230609100933206

三. 异步事件发布处理

定义一个 订单成功后 发布邮件的功能, 希望订单和邮件是个异步的操作。

三.一 发布主体 MailMessageEvent

public class MailMessageEvent extends ApplicationEvent {
	private String message;
	
	public MailMessageEvent(Object source, String message) {
		super(source);
		this.message = message;
	}
	
	public String getMessage() {
		return message;
	}
}

三.二 邮件Listener

@Component
@Slf4j
public class MailListener implements ApplicationListener<MailMessageEvent> {
	
	@Override
	public void onApplicationEvent(MailMessageEvent mailMessageEvent) {
		log.info(">>>>执行发送邮件事件监听的操作,{}", mailMessageEvent.getMessage());
		try {
			TimeUnit.SECONDS.sleep(4);
			log.info(">>>>> 邮件发送成功");
		} catch (Exception e) {
			e.printStackTrace();
		}
		log.info(">>>邮件事件监听结束");
	}
}

三.三 调用发布

OrderEventService 类中:

	public void handlerEmail(String message) {
		log.info(">>>>开始处理订单,订单信息是:{}", message);
		//处理具体的业务信息
		handlerOrder(message);
		//发送邮件程序
		applicationContext.publishEvent(new MailMessageEvent(this, "发送邮件"));
		log.info(">>>> 调用订单程序成功,任务结束");
	}

三.四 测试验证

@Test
	public void asyncTest() {
		orderEventService.handlerEmail("岳泽霖购买护肤品");
		try {
			TimeUnit.SECONDS.sleep(12);
		} catch (Exception e) {
		
		}
	}

订单是3 s, 邮件是 4s

image-20230609101814858

可以观察到, 共花费了 7s 的时长。 先执行了订单(3s), 再执行邮件发送 (4s)

三.五 异步调用

三.五.一 启动类上添加 @EnableAsync 注解

image-20230609101929285

三.五.二 监听器 方法上添加 @Async 注解

image-20230609102228358

image-20230609102009621

执行验证, 共使用了 4s , 异步是成功的.

image-20230609102250976


本章节的代码放置在 github 上:

https://github.com/yuejianli/Function/tree/develop/SpringEvent


谢谢您的观看,如果喜欢,请关注我,再次感谢 !!!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/627093.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Windows 10磁盘碎片整理:含义和操作方法

什么是Windows磁盘碎片&#xff1f; 随着电脑硬盘使用时间的增长&#xff0c;磁盘上会产生大量的垃圾碎片。这些碎片会分布在磁盘的各个角落&#xff0c;严重影响磁盘的响应速度。为了在一定程度上提高系统性能&#xff0c;定期使用Windows10的磁盘碎片整理工具来进行碎片整…

Vue.js中的Mixin和组件插槽

Vue.js中的Mixin和组件插槽 介绍 在Vue.js中&#xff0c;Mixin和组件插槽是两个非常有用的概念。Mixin是一种可重用Vue组件的方式&#xff0c;而组件插槽则提供了一种在组件之间共享内容的方式。虽然这两个概念在功能上有所不同&#xff0c;但它们对于Vue.js应用程序的开发都非…

Vue 中的数据请求如何进行拦截与错误处理

Vue 中的数据请求拦截与错误处理 在 Vue.js 中&#xff0c;我们经常需要向后端服务器发送数据请求&#xff0c;以获取或提交数据。在这个过程中&#xff0c;我们可能会遇到一些问题&#xff0c;例如无效的请求参数、网络连接错误、服务器错误等。为了更好地处理这些问题&#…

优化和扩展:处理不同操作和参数的数字列表

引言 在编程中&#xff0c;我们有时需要根据输入执行不同的操作&#xff0c;而这些操作涉及到数字列表&#xff0c;并且每个操作可能具有不同数量的参数。本文将介绍如何优化和扩展代码&#xff0c;以便更好地处理这种情况。 问题描述 当前遇到的问题是需要根据输入执行不同…

Mysql中的Buffer pool

Buffer Pool在数据库里的地位 1、回顾一下Buffer Pool是个什么东西&#xff1f; 数据库中的Buffer Pool是个什么东西&#xff1f;其实他是一个非常关键的组件&#xff0c;数据库中的数据实际上最终都是要存放在磁盘文件上的&#xff0c;如下图所示。 但是我们在对数据库执行增…

2023最新Java面试八股文,阿里/腾讯 / 美团 / 字节 1 000道 Java 中高级面试题

企业调薪、裁员、组织架构调整等等&#xff0c;坏消息只多不少&#xff0c;最近也有很多来咨询跳槽的朋友&#xff0c;都是因为之前的公司出现了比较大的薪资和组织变动 近期有许多粉丝非常关注最新的面试题&#xff01;于是小编去各大平台搜罗了一份近期大厂面试的一些内容&a…

基础工程(cubeide串口调试,printf实现,延时函数)

0.基础工程&#xff08;cubeide串口调试&#xff0c;printf实现&#xff0c;延时函数&#xff09; 文章目录 0.基础工程&#xff08;cubeide串口调试&#xff0c;printf实现&#xff0c;延时函数&#xff09;外部时钟源CLOCK(RCC)系统时钟SYS与DEBUG设置UART串口设置cubeide设置…

世界研发管理组织在美国成立,中国籍研发管理专家江新安当选总干事

World R&D Management Organization世界研发管理组织&#xff08;WRDMO&#xff09;由来自世界各地的研发管理研究组织&#xff0c;创新技术研究机构&#xff0c;院校以及研发管理咨询机构联合发起。是一个具有开放性&#xff0c;无党派性&#xff0c;非营利性的国际先进研…

如从亿点点失误,到一点点失误,我是如何做的【工作失误怎么办】

前言 只要我们还在做事&#xff0c;或者说还活着&#xff0c;就没有不犯错的时候。作为一名前端搬砖工&#xff0c;哪怕工作中再仔细小心&#xff0c;也免不了一些失误。 那这是不是说&#xff0c;失误很正常&#xff0c;改了就是嘛&#xff1f; 这么说好像没错。作为失误本…

【计算机组成与体系结构Ⅰ】知识点整理

第一章 计算机系统概论 1.1 从源文件到可执行文件 .c源程序、.i源程序、.s汇编语言程序、.o可重定位目标程序、可执行目标程序&#xff1b;后两个为二进制&#xff0c;前面为文本 1.2 可执行文件的启动和执行 冯诺依曼结构计算机模型的5大基本部件&#xff1a;运算器、控制…

【ChatGLM】使用ChatGLM-6B-INT4模型进行P-Tunning训练记录及参数讲解

文章目录 模型训练步骤参数含义名词解释欠拟合泛化能力收敛性梯度爆炸 初步结论 小结 模型训练 首先说明一下训练的目的&#xff1a;提供本地问答知识文件&#xff0c;训练之后可以按接近原文语义进行回答&#xff0c;类似一个问答机器人。 步骤 安装微调需要的依赖&#xf…

C++【哈希表封装unordered_map/set】—含有源代码

文章目录 &#xff08;1&#xff09;修改原哈希表&#xff08;2&#xff09;迭代器&#xff08;3&#xff09;最后一步&#xff08;4&#xff09;关于key是自定义类型的额外补充(面试题)&#xff08;5&#xff09;源代码 &#xff08;1&#xff09;修改原哈希表 和红黑树封装一…

【链表Part01】| 203.移除链表元素、707.设计链表、206.反转链表

目录 ✿LeetCode203.移除链表元素❀ ✿LeetCode707.设计链表❀ ✿LeetCode206.反转链表❀ ✿LeetCode203.移除链表元素❀ 链接&#xff1a;203.移除链表元素 给你一个链表的头节点 head 和一个整数 val &#xff0c;请你删除链表中所有满足 Node.val val 的节点&#xff…

python数据分析

一、数据处理 1.爬取数据 我们将使用Python的requests和BeautifulSoup库来爬取数据。在这个示例中&#xff0c;我们将爬取豆瓣电影Top250的数据。 import requests from bs4 import BeautifulSoup url https://movie.douban.com/top250 headers {User-Agent: Mozilla/5.0 …

策略设计模式解读

目录 问题引进 鸭子问题 传统方案解决鸭子问题的分析和代码实现 传统的方式实现的问题分析和解决方案 策略模式基本介绍 基本介绍 策略模式的原理类图 策略模式解决鸭子问题 策略模式的注意事项和细节 问题引进 鸭子问题 编写鸭子项目&#xff0c;具体要求如下: 1) 有…

【GlobalMapper精品教程】059:基于las点云创建数字高程地形并二三维着色显示

本文讲述在globalmapper免费中文版中基于地形点云las数据创建数字高程地形、数字高程二三维联动可视化并进行数字高程着色显示。 文章目录 一、加载地形点云las数据二、创建数字高程地形三、数字高程二三维联动可视化四、数字高程着色显示相关阅读:ArcGIS实验教程——实验二十…

如何看待 Facebook 上线支付功能?

随着科技的不断进步&#xff0c;电子支付在我们的生活中变得越来越普遍。最近&#xff0c;Facebook宣布推出自己的支付功能&#xff0c;这引起了广泛的关注和讨论。作为世界上最大的社交媒体平台之一&#xff0c;Facebook进入支付领域的举措无疑具有重要意义。那么&#xff0c;…

Jetpack Compose:使用PagerIndicator和Infinity实现滚动的HorizontalPager

Jetpack Compose&#xff1a;使用PagerIndicator和Infinity实现滚动的HorizontalPager 可能你已经知道&#xff0c;Jetpack Compose 默认不包含内置的ViewPager组件。然而&#xff0c;我们可以通过在 build.gradle 文件中添加 accompanist 库依赖&#xff0c;将 ViewPager 功能…

有了这套方案,企业降本增效不再是纸上谈兵 (2)

一、生存压力逼近&#xff0c;企业如何应对经济下行残酷挑战&#xff1f; 当前市场经济下滑&#xff0c;客户预算紧缩和投资削减可能导致IT项目推迟或取消&#xff0c;从而直接影响公司收入和盈利能力。各大厂商都在陆续裁员或调整业务&#xff0c;以人力等成本为主的IT公司也必…

双塔模型dssm实践

最近在学习向量召回&#xff0c;向量召回不得不用到dssm双塔模型&#xff0c;双塔模型的原理非常简单&#xff0c;就是用两个任务塔&#xff0c;一个是query侧的query任务塔&#xff0c;另一个是doc侧的doc任务塔&#xff0c;任务塔向上抽象形成verctor隐向量后&#xff0c;用c…