SpringBoot-自定义监听器

Spring Boot提供了强大的事件模型,其中包括多种内置监听器,同时也支持开发者自定义监听器。通过实现`ApplicationListener`接口,开发者可以创建自己的监听器,并在Spring Boot应用程序中进行配置。这样一来,在特定的应用程序事件发生时,自定义监听器就能够捕捉到并执行相应的操作,比如读取配置文件、初始化数据等。

自定义监听器的使用不仅仅是为了满足基本的业务需求,更是为了提高应用程序的可维护性和可靠性。通过监控应用程序的运行状态,开发人员可以更加及时地发现潜在的问题,并采取相应的措施。这有助于降低应用程序的故障风险,提高系统的稳定性。

此外,自定义监听器为开发人员提供了一种灵活的扩展方式,使其能够更好地适应不同的业务场景。开发者可以根据具体需求实现不同的监听器,以满足特定功能或业务逻辑的要求。这种灵活性使得Spring Boot应用程序更具可扩展性,更容易应对日益变化的业务需求。

自定义监听器作为Spring Boot框架中强大而灵活的一部分,为开发人员提供了有效的工具,帮助他们更好地监控和管理应用程序,同时为系统的可靠性和可维护性注入了更多的可能性。


一、创建自定义监听器

要创建自定义监听器,首先需要新建一个类,我们称之为MyApplicationListener,并确保该类继承了ApplicationListener接口。这一接口规定了一个名为onApplicationEvent的方法,我们将在这个方法中定义我们监听到特定应用程序事件时的操作。下面是一个简单的实例:

MyApplicationListener.java代码:

import org.springframework.context.ApplicationEvent;
import org.springframework.context.ApplicationListener;
import org.springframework.stereotype.Component;@Component
public class MyApplicationListener implements ApplicationListener<ApplicationEvent> {@Overridepublic void onApplicationEvent(ApplicationEvent event) {// 在这里编写监听到特定应用程序事件时的操作// 例如,利用RedisUtil工具类往Redis里写入数据RedisUtil.writeDataToRedis();}
}

在上述代码中,MyApplicationListener类通过实现ApplicationListener接口,成为了一个Spring Bean(通过@Component注解)。这使得Spring Boot应用程序能够自动扫描并注册这个监听器。 


二、利用RedisUtil工具类写入数据

为了在onApplicationEvent方法中使用RedisUtil工具类往Redis里写入数据,我们需要确保RedisUtil类已经存在,并且包含了相关的写入方法。下面是一个简单的示例:

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.data.redis.core.RedisTemplate;
import org.springframework.stereotype.Component;@Component
public class RedisUtil {private final RedisTemplate<String, String> redisTemplate;@Autowiredpublic RedisUtil(RedisTemplate<String, String> redisTemplate) {this.redisTemplate = redisTemplate;}public void writeDataToRedis() {// 在这里编写往Redis里写入数据的逻辑redisTemplate.opsForValue().set("key", "value");}
}

在上述代码中,RedisUtil类通过@Component注解成为了一个Spring Bean,使得它可以被其他组件自动注入。writeDataToRedis方法可以根据具体需求编写,执行向Redis写入数据的相关逻辑。

通过这样的设计,我们成功创建了一个自定义监听器MyApplicationListener,在特定应用程序事件发生时,它会调用RedisUtil工具类的方法,实现了向Redis写入数据的功能。这种结构既利用了Spring Boot的事件模型,又灵活地整合了自定义逻辑,为应用程序提供了更多的扩展性和定制化的可能性。


三、测试自定义监听器

接下来,我们将进行自定义监听器的测试,确保它在项目加载时能够自动运行并执行相关操作。

1、观察控制台输出

启动项目,并仔细观察控制台输出。若一切配置正确,你应该能够看到与自定义监听器相关的日志信息。这些日志表明监听器在特定应用程序事件发生时被触发,执行了相应的操作。

我们往监听器里添加日志代码:

import org.springframework.context.ApplicationEvent;
import org.springframework.context.ApplicationListener;
import org.springframework.stereotype.Component;@Component
public class MyApplicationListener implements ApplicationListener<ApplicationEvent> {@Overridepublic void onApplicationEvent(ApplicationEvent event) {// Spring Boot 应用启动后执行该方法System.out.println("Spring Boot 应用启动...");// 在这里编写监听到特定应用程序事件时的操作// 例如,利用RedisUtil工具类往Redis里写入数据RedisUtil.writeDataToRedis();System.out.println("将数据存入 Redis 中...");}
}

启动项目,观察控制台,看到我们的log已经被打出了。

这表示MyApplicationListenerApplicationEvent发生时被触发。 

2、检查Redis是否成功存入

接着,我们来进行第二项测试,确保数据已成功存入Redis。我们要通过访问Redis服务,检查相关数据是否已被写入。具体方法我们采用使用命令行工具或可视化工具连接到Redis服务器的形式,检查键值对是否存在。我们在writeDataToRedis方法中写入了键为 "key"、值为 "value" 的数据,应该在Redis中可以看到相应的数据。 

我们去访问Reids服务,看内容是否已经被存入Redis,看到已经被存入。输入Keys,获得Redis服务保存的所有键值对,如果成功的话,可以看到我们刚刚存入的<"key", “value”>键值对的key,也就是字符串"key"。

通过以上两个测试步骤,我们已经验证自定义监听器在按照预期工作。


四、自定义监听器的四种实现方式

在Spring Boot中,我们可以通过不同的方式来自定义监听器。以下是几种常见的方法,以及简单的示例:

1、实现ApplicationListener接口

import org.springframework.context.ApplicationEvent;
import org.springframework.context.ApplicationListener;
import org.springframework.stereotype.Component;@Component
public class CustomEventListener implements ApplicationListener<ApplicationEvent> {@Overridepublic void onApplicationEvent(ApplicationEvent event) {// 处理事件逻辑System.out.println("Custom Event Received: " + event.toString());}
}

2、使用@EventListener注解

import org.springframework.context.event.EventListener;
import org.springframework.stereotype.Component;@Component
public class AnotherCustomEventListener {@EventListenerpublic void handleCustomEvent(CustomEvent customEvent) {// 处理事件逻辑System.out.println("Another Custom Event Received: " + customEvent.toString());}
}

在这个例子中,CustomEvent是自定义的事件类,根据需要定义自己的事件。 

3、实现ApplicationEventPublisherAware接口

import org.springframework.context.ApplicationEventPublisher;
import org.springframework.context.ApplicationEventPublisherAware;
import org.springframework.stereotype.Component;@Component
public class CustomEventPublisher implements ApplicationEventPublisherAware {private ApplicationEventPublisher eventPublisher;@Overridepublic void setApplicationEventPublisher(ApplicationEventPublisher applicationEventPublisher) {this.eventPublisher = applicationEventPublisher;}public void publishCustomEvent(String message) {// 创建并发布自定义事件CustomEvent customEvent = new CustomEvent(this, message);eventPublisher.publishEvent(customEvent);}
}

上述示例中的CustomEvent是一个自定义的事件类,根据实际需求创建。 

4、使用@Async注解实现异步监听

import org.springframework.context.event.EventListener;
import org.springframework.scheduling.annotation.Async;
import org.springframework.stereotype.Component;@Component
public class AsyncEventListener {@Async@EventListenerpublic void handleAsyncEvent(CustomAsyncEvent asyncEvent) {// 异步处理事件逻辑System.out.println("Async Custom Event Received: " + asyncEvent.toString());}
}

通过在方法上添加@Async注解,可以使监听器在异步线程中处理事件。

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

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

相关文章

python 函数中字典的修改会影响函数外字典的值

def modify_dict(d):d[key] new valueprint(函数中字典d的位置,id(d))# 创建一个字典 original_dict {key: old value} print(函数外字典的位置,id(original_dict))# 调用函数来修改字典 modify_dict(original_dict)# 输出原始字典的值&#xff0c;可以看到它已经被修改了 pr…

一种DevOpts的实现方式:基于gitlab的CICD(二)

写在之前 前文已经搭建了基于gitlab的cicd环境&#xff0c;现在我们来更近一步&#xff0c;结合官网给出的案例来详细介绍如何一步一步实现CI的过程。 基于gitlab搭建一个前端静态页面 环境依赖&#xff1a; gitlabgitlab runner&#xff08;docker版本&#xff09; 环境达吉…

04、Kafka ------ 各个功能的作用解释(Cluster、集群、Broker、位移主题、复制因子、领导者副本、主题)

目录 启动命令&#xff1a;CMAK的用法★ 在CMAK中添加 Cluster★ 在CMAK中查看指定集群★ 在CMAK中查看 Broker★ 位移主题★ 复制因子★ 领导者副本和追随者副本★ 查看主题 启动命令&#xff1a; 1、启动 zookeeper 服务器端 小黑窗输入命令&#xff1a; zkServer 2、启动 …

【REST2SQL】06 GO 跨包接口重构代码

【REST2SQL】01RDB关系型数据库REST初设计 【REST2SQL】02 GO连接Oracle数据库 【REST2SQL】03 GO读取JSON文件 【REST2SQL】04 REST2SQL第一版Oracle版实现 【REST2SQL】05 GO 操作 达梦 数据库 对所有关系数据的操作都只有CRUD&#xff0c;采用Go 的接口interface{}重构代码…

Large Language Models Paper 分享

论文1&#xff1a; ChatGPTs One-year Anniversary: Are Open-Source Large Language Models Catching up? 简介 2022年11月&#xff0c;OpenAI发布了ChatGPT&#xff0c;这一事件在AI社区甚至全世界引起了轰动。首次&#xff0c;一个基于应用的AI聊天机器人能够提供有帮助、…

属性动画的使用

文章目录 1 概述2 创建属性动画页面3 属性动画参数调整延时播放时间delay的设置onFinish回调函数的使用 4 关闭属性动画页面5 参考 1 概述 属性动画&#xff0c;是最为基础的动画&#xff0c;其功能强大、使用场景多&#xff0c;应用范围较广。常用于如下场景中&#xff1a; …

第九节HarmonyOS 常用基础组件12-TextTimer

1、描述 通过文本显示计时信息并控制其计时器状态的组件。 2、接口 TextTimer(options?: {isCountDown?: boolean, count?: number, controller?: TextTimerController}) 3、参数 参数名称 参数类型 必填 描述 isCountDown boolean 否 是否倒计时。默认值&#…

Kafka与RabbitMQ的区别

消息队列介绍 消息队列&#xff08;Message Queue&#xff09;是一种在分布式系统中进行异步通信的机制。它允许一个或多个生产者在发送消息时暂时将消息存储在队列中&#xff0c;然后由一个或多个消费者按顺序读取并处理这些消息。 消息队列具有以下特点&#xff1a; 异步通…

64.网游逆向分析与插件开发-游戏增加自动化助手接口-优化自动助手与游戏焦点的切换

内容来源于&#xff1a;易道云信息技术研究院VIP课 上一个内容&#xff1a;自动化助手UI与游戏菜单的对接-CSDN博客 码云地址&#xff08;master分支&#xff09;&#xff1a;https://gitee.com/dye_your_fingers/sro_-ex.git 码云版本号&#xff1a;617ac3477ef18273fb9cc2…

Linux文件系统与日志服务管理

目录 一.Linux文件系统 1.inode表和block &#xff08;1&#xff09;inode &#xff08;2&#xff09;block 2.查看inode号命令 3.Linux系统文件三种主要时间属性 4.磁盘空间还剩余很多但无法继续创建文件 5.inode大小 二.日志 1.日志保存位置 2.日志文件的分类 &a…

Selenium 学习(0.17)——软件测试之流程图绘制方法

病假5天&#xff0c;出去野20天&#xff0c;成功错过了慕课网上的期末考试。 害&#xff0c;都怪玩乐太开心了…… 反正咱又不指着全靠这个行当来吃饭&#xff0c;错过也就错过了&#xff0c;立的Flag能抢救一下还是要抢救一下吧。【这个其实早都会画了&#xff0c;而且基本也正…

Mac robotframework+pycharm运行suite报错情况:ImportError: No module named request

报错实例&#xff1a; 当前Preferences–>Tool–>External Tools Suite配置&#xff0c;显示使用的python为2.7版本&#xff0c;robotframework安装在当前版本的python中&#xff1a; 但是我pycharm现在的环境配置的python为3.11&#xff0c;当前使用的RF与当前使用的py…

NoSQL概述与Redis入门-redis安装与测试

一、Nosql概述 1、为什么使用Nosql 1、单机Mysql时代 90年代,一个网站的访问量一般不会太大&#xff0c;单个数据库完全够用。随着用户增多&#xff0c;网站出现以下问题 数据量增加到一定程度&#xff0c;单机数据库就放不下了数据的索引&#xff08;B Tree&#xff09;,一个…

关于外连接、内连接和子查询的使用(2)

目录 一. 前言 二. 使用外连接、内连接和子查询进行解答 三. 思维导图 一. 前言 在前面我们对外连接、内连接和子查询的使用有了一些了解&#xff0c;今天我们将继续更深入的进行学习。&#xff08;这里缺少的八个题目在博主的前面博客有解答&#xff0c;大家可以移步前面一…

zabbix-proxy代理安装

zabbix-proxy代理安装 安装zabbix-proxyserver端配置zabbix-proxy配置被监控的agent安装中问题解决监控网络设备JMX和IPMI监控方式 zabbix-proxy的安装&#xff0c;至少需要准备三台机器&#xff0c;一台安装服务端&#xff0c;一台安装agent端&#xff0c;这里就不叙述了&…

OBD汽车

相当于客户端与服务器 诊断设备流程 》》》》诊断服务 OBD很多的定死了 Vme就很灵活 WWH 就是两个的结合 OBD15031 SID PID 可以自己定义一些 一个字节255个 两个有效字节 02 01 0D 5555&#xff08;随机值&#xff09;这是请求 两个有效字节 01 OD&#xff08;请求速…

51单片机之按键和数码管

51单片机之按键和数码管 ✍前言&#xff1a;♐独立按键&#x1f600;独立按键的原理&#x1f600;软件实现按键控制LED灯的亮灭 ♐数码管&#x1f60a;数码管显示数字或者字母的原理&#x1f409;共阳极数码管&#x1f409;共阴极极数码管&#x1f409;4位1体数码管 &#x1f6…

大数据StarRocks(六) :Catalog

StarRocks 自 2.3 版本起支持 Catalog&#xff08;数据目录&#xff09;功能&#xff0c;实现在一套系统内同时维护内、外部数据&#xff0c;方便您轻松访问并查询存储在各类外部源的数据。 1. 基本概念 内部数据&#xff1a;指保存在 StarRocks 中的数据。 外部数据&#xf…

分布式系统架构设计之分布式消息队列架构解析

分布式消息队列架构是构建在分布式系统之上的消息队列架构&#xff0c;旨在提高高性能、高可用性和可伸缩性。它包括以下架构相关部分&#xff1a; 1、架构优势 分布式消息队列架构的优势主要体现在以下几个方面&#xff1a; 01 高可用性 在分布式消息队列架构中&#xff0…

ARM架构—— Cortex-M3与Cortex-M4特点概述

一、Cortex-M3与Cortex-M4异同点 相同点&#xff1a; 基于ARM-v7-M架构。三级流水线设计。哈佛总线架构&#xff0c;统一的存储器空间&#xff1a;指令和地址总线使用相同的地址空间。32位寻址&#xff0c;支持4GB 存储空间。基于ARM AMBA&#xff08;高级微控制器总线架构&a…