1、使用AOP, 引入aop依赖
<dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-aop</artifactId> </dependency>
2、新增 ServiceLogAspect.java 配置AOP通知,重点是环绕通知,切面表达式

package com.imooc.aspect; import org.aspectj.lang.ProceedingJoinPoint; import org.aspectj.lang.annotation.Around; import org.aspectj.lang.annotation.Aspect; import org.slf4j.Logger; import org.slf4j.LoggerFactory; import org.springframework.stereotype.Component; @Component @Aspect public class ServiceLogAspect { public static final Logger logger = LoggerFactory.getLogger(ServiceLogAspect.class); /* *AOP通知: * 1.前置通知:在方法调用之前执行 * 2.后置通知:在方法正常调用之后执行 * 3.环绕通知:在方法调用之前和之后,都分别可以执行的通知 * 4.异常通知:如果在方法调用过程中发生异常,则通知 * 5.最终通知:在方法调用之后执行 */ /** * 切面表达式 * execution 代表所有执行的表达式主体 * 第一处 * 代表方法返回类型 *代表所有类型 * 第二处 包名代表aop监控的类所在的包 * 第三处 。。 代表该包以及其子包下的所有类方法 * 第四处 * 代表类名,*代表所有类 * 第五处 *(..) *代表类中的方法名,(..)表示方法中的任何参数 * @param joinPoint * @return * @throws Throwable */ @Around("execution(* com.imooc.service.impl..*.*(..))") public Object recordTimeLog(ProceedingJoinPoint joinPoint) throws Throwable { logger.info("======== 开始执行 {}.{}==========", joinPoint.getTarget().getClass(), joinPoint.getSignature().getName()); long beginTime = System.currentTimeMillis(); Object result= joinPoint.proceed(); long endTime = System.currentTimeMillis(); long takeTime=endTime - beginTime; if (takeTime >3000 ) { logger.error("====== 执行结束,耗时:{} 毫秒 ======",takeTime); }else if(takeTime>2000){ logger.warn("====== 执行结束,耗时:{} 毫秒 ======",takeTime); }else { logger.info("====== 执行结束,耗时:{} 毫秒 ======",takeTime); } return result; } }
3.开启mybatis sql执行日志打印
修改 src/main/resources/application.yml
############################################################
#
# mybatis 配置
#
############################################################
mybatis:
type-aliases-package: com.imooc.pojo # 所有POJO类所在包路径
mapper-locations: classpath:mapper/*.xml # mapper映射文件
configuration:
log-impl: org.apache.ibatis.logging.stdout.StdOutImpl
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· winform 绘制太阳,地球,月球 运作规律
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· AI与.NET技术实操系列(五):向量存储与相似性搜索在 .NET 中的实现
· 超详细:普通电脑也行Windows部署deepseek R1训练数据并当服务器共享给他人
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理