文章目录

      • 实现说明:
      • 注意事项:

要在Spring中通过BeanPostProcessor接口计算并打印每个Bean的加载耗时,我们可以利用该接口的两个回调方法记录Bean初始化前后的时间戳,然后计算时间差。

以下是实现方案:

  1. 首先创建一个实现BeanPostProcessor接口的类
  2. 使用线程安全的Map存储每个Bean的初始化开始时间
  3. postProcessBeforeInitialization中记录开始时间
  4. postProcessAfterInitialization中计算并打印耗时
import org.springframework.beans.BeansException;
import org.springframework.beans.factory.config.BeanPostProcessor;
import org.springframework.stereotype.Component;
import java.util.HashMap;
import java.util.Map;
import java.util.concurrent.ConcurrentHashMap;/*** 计算并打印每个Bean的加载耗时*/
@Component
public class BeanInitializationTimer implements BeanPostProcessor {// 使用线程安全的Map存储Bean初始化开始时间private final Map<String, Long> startTimeMap = new ConcurrentHashMap<>();/*** Bean初始化之前调用,记录开始时间*/@Overridepublic Object postProcessBeforeInitialization(Object bean, String beanName) throws BeansException {// 记录当前时间戳作为开始时间startTimeMap.put(beanName, System.currentTimeMillis());return bean;}/*** Bean初始化之后调用,计算并打印耗时*/@Overridepublic Object postProcessAfterInitialization(Object bean, String beanName) throws BeansException {// 获取开始时间Long startTime = startTimeMap.get(beanName);if (startTime != null) {// 计算耗时long endTime = System.currentTimeMillis();long duration = endTime - startTime;// 打印Bean加载耗时信息System.out.printf("Bean '%s' 初始化完成,类型: %s,耗时: %d ms%n",beanName, bean.getClass().getSimpleName(), duration);// 移除已处理的Bean记录,释放内存startTimeMap.remove(beanName);}return bean;}
}

实现说明:

  1. 组件注册:通过@Component注解将该处理器注册为Spring组件,Spring会自动发现并使用它
  2. 时间记录
  • postProcessBeforeInitialization方法中,记录每个Bean开始初始化的时间戳
  • 使用ConcurrentHashMap确保在多线程环境下的线程安全
  1. 耗时计算
  • postProcessAfterInitialization方法中,计算当前时间与开始时间的差值
  • 打印Bean名称、类型和初始化耗时
  • 处理完成后从Map中移除记录,避免内存泄漏
  1. 使用方式:只需将该类放入Spring扫描路径下,Spring容器启动时就会自动使用该处理器,无需额外配置

注意事项:

  • 该耗时包括Bean的初始化方法(如@PostConstruct标注的方法)执行时间
  • 如果Bean没有初始化方法,耗时会非常短
  • 对于懒加载的Bean,会在第一次被获取时才会计算耗时
  • 输出结果会显示在控制台,按Bean初始化完成的顺序打印

通过这种方式,你可以很方便地监控Spring容器中所有Bean的初始化性能,识别出初始化耗时较长的Bean,为性能优化提供依据。

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

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

相关文章

“品种+创新销售”,恩威医药半年度业绩翻倍增长

8月25日晚&#xff0c;恩威医药发布2025年半年度报告&#xff0c;报告期内&#xff0c;公司实现营业收入4.49亿元&#xff0c;同比增长15.73%&#xff0c;归属于上市公司股东净利润达3834.42万元&#xff0c;同比增幅113.80%&#xff0c;扣除非经常性损益净利润为3527.57万元&a…

【机器学习】机器学习算法

机器学习1、K-近邻算法KNN1.1、举例&#xff1a;电影类型分析1.2、KNN算法流程1.3、Scikit-learn工具1.4、K-近邻算法API1.5、距离度量1.5.1、欧式距离Euclidean Distance&#x1f525;1.5.2、曼哈顿距离Manhattan Distance&#x1f525;1.5.3、切比雪夫距离Chebyshev Distance…

python-批量安装库

要将当前环境中已安装的Python库列表导出为一个可重用的格式&#xff08;通常为requirements.txt&#xff09;&#xff0c;以便在另一个环境中再现这些库的安装&#xff0c;可以使用pip工具提供的功能。以下是具体步骤&#xff1a;### 使用pip freeze1. **打开命令提示符或终端…

创龙3576ububuntu系统设置静态IP方法

创龙3576ububuntu系统设置静态IP方法&#xff0c;执行命令进入"/etc/systemd/network/"目录&#xff0c;请根据实际网络环境&#xff0c;下面演示修改 eth0.network 网口静态ip为192.168.1337.200执行&#xff1a;vim /etc/systemd/network/eth0.network 增加一句&am…

MySQL - 视图,事务和索引

目录一、视图1. 问题2. 视图是什么3. 定义视图4. 查看视图5. 使用视图6. 删除视图7. 视图的作用二、事务1. 定义2. 事务命令1&#xff09;回滚2&#xff09;提交3&#xff09;脏写、脏读、不可重复读和幻读三、索引1. 定义2. 索引是什么3. 索引目的4. 索引原理5. 索引的使用6. …

车载铁框矫平机:把“钣金诊所”开到工地上

——一次从原子层面开始的平整之旅一、先想一想&#xff1a;铁框为什么“脾气大” 钢板在轧制、切割、焊接、吊装、甚至太阳暴晒时&#xff0c;内部晶粒被拉得七扭八歪&#xff0c;像揉皱的纸。宏观上&#xff0c;我们就看到“翘、拱、扭”。矫平&#xff0c;实质上是给金属做一…

不安全的服务器,不支持 FTP over TLS

当服务器不支持 FTP over TLS&#xff08;也称为 FTPS&#xff09;时&#xff0c;意味着它仅支持未加密的 FTP 连接。这种情况存在显著的安全风险&#xff0c;因为&#xff1a;数据传输不加密&#xff1a;用户名、密码以及传输的文件内容都会以明文形式在网络中传输&#xff0c…

本地缓存与 Redis 缓存的区别与实际应用

缓存是提升系统性能、降低数据库压力的重要手段。Java 开发中常用的缓存方案包括 ​本地缓存&#xff08;如 Caffeine、Guava Cache&#xff09;​​ 和 ​分布式缓存&#xff08;如 Redis&#xff09;​。这两者在设计目标、使用场景、性能特点等方面有显著差异&#xff0c;合…

从“0”开始学JAVA——第十一节 I/O流

在Java编程中&#xff0c;文件操作和输入输出(IO)处理是必不可少的部分。本文将深入探讨Java IO包中的文件流操作&#xff0c;包括基础概念、分类、常用类以及实际应用场景。1. File类File类是Java IO操作的基础&#xff0c;它实现了Serializable和Comparable<File>接口。…

【数据价值化】数据资产入表指南:核心准则与实操路径

随着数据要素市场的蓬勃发展&#xff0c;数据资产的商业价值愈发凸显。然而&#xff0c;如何让数据资产合规、合理地进入企业财务报表&#xff0c;成为众多企业急需解决的难题。本文基于《企业会计准则》的相关规定&#xff0c;为您系统梳理数据资产入表的核心准则要点与实操路…

基于 MediaPipe + Three.js 的实时姿态可视化前端

这是一套前端实时姿态捕获与 3D 可视化的 DEMO&#xff0c;特点是启动快、UI 现代、渲染稳定&#xff0c;同时对设备性能与网络情况做了多处优化。 预览地址 技术栈与核心依赖 框架与工程&#xff1a;Vite React TypeScript实时姿态识别&#xff1a;MediaPipe Tasks Vision&…

【分布式技术】Kafka 数据积压全面解析:原因、诊断与解决方案

Kafka 数据积压全面解析&#xff1a;原因、诊断与解决方案Kafka 数据积压深度解析与解决方案全景指南一、数据积压核心原因矩阵二、生产者侧问题深度解析1. 突发流量洪峰2. 大消息阻塞管道三、消费者侧问题深度解析1. 消费能力不足2. 消费逻辑阻塞四、Broker集群问题深度解析1.…

企业云办公安全指南:如何构建高效无忧的云办公环境?

2025年&#xff0c;全球化协作与混合办公已成为企业运营的常态。越来越多的企业将业务迁移至云端&#xff0c;云办公在提升灵活性与效率的同时&#xff0c;也带来了新的安全挑战——数据泄露、内部威胁、网络攻击等风险无处不在&#xff0c;每一个环节都可能成为企业核心资产的…

Thingsboard 租户管理员权限,增加租户普通用户权限

在 ThingsBoard CE&#xff08;社区版&#xff09;中&#xff0c;租户管理员拥有对规则链、客户、资产、设备、仪表板等资源的全面管理权限。如果你想为租户创建一个普通用户&#xff0c;并限制其不能操作规则链、高级功能、安全设置等&#xff0c;可以通过以下步骤实现&#x…

【笔记】大模型业务场景流程综述

前言 大模型是指具有大规模参数和复杂计算结构的深度学习模型,这些模型通常由众多神经网络构建而成,拥有数十亿甚至数千亿个参数。本章将围绕大模型概念及特点展开,介绍模型算法的分类、典型大模型及应用、大模型训练流程和大模型业务流程。 目标 学完本课程后,您将能够…

【两数相互求余等于输入两数】2022-10-20

缘由关于#c#的问题&#xff1a;这个应该按照怎么个思路来写&#xff1a;想老半天莫得思路想法-编程语言-CSDN问答 void 两数相互求余等于输入两数() {//缘由https://ask.csdn.net/questions/7813625int a 0, b 0, x 0, y 0;cin >> a >> b;if (a > b)x a, y…

Linux系统调优

目录 1.CPU 负载查看 1.1.使用 uptime 查看系统负载 1.2.使用 top 按 CPU 使用率排序 1.3.使用 ps 查看 CPU 使用最多的进程 1.4.使用 mpstat 查看 CPU 详细状态 1.5.查看 /proc/meminfo 获取详细内存信息 2查看内存运行状态 2.1.使用 free 查看内存使用 1.CPU 负载查看…

AtCoder Beginner Contest 420

比赛链接如下&#xff1a; AtCoder Beginner Contest 420 - AtCoder A - What month is it? Problem Statement You are given integers X and Y between 1 and 12, inclusive. Find what month it will be Y months after month X (for example, month 1 is January). Cons…

Python算法-贪心算法(Greedy Algorithm)

Python算法&#xff1a;贪心算法&#xff08;Greedy Algorithm&#xff09;深度解析 引言 贪心算法&#xff08;Greedy Algorithm&#xff09;是计算机科学中最基础的算法设计思想之一&#xff0c;其核心在于通过局部最优选择逐步构建全局最优解。尽管它并不总能保证得到绝对最…

告别臃肿与广告:精选9款安卓电视桌面Launcher,还你清爽高效体验 (2025版)

[实测] 9款优秀安卓电视桌面Launcher推荐&#xff1a;告别原生臃肿&#xff0c;重塑清爽TV体验 引言&#xff1a;当前智能电视桌面的痛点 目前市面上许多智能电视或电视盒子的原生桌面&#xff08;Launcher&#xff09;系统&#xff0c;为了商业推广和内容聚合&#xff0c;往…