java - 如何使用 Spring AOP 和 SPring boot 进行日志记录
问题描述
我使用与本示例教程https://www.javaguides.net/2019/05/spring-boot-spring-aop-logging-example-tutorial.html相同的类 LoggingAspect ,但是当我调用控制器方法时,我得到只有控制台上的那些消息
11-05-2020 13:30:27.742 [http-nio-8080-exec-7] INFO o.a.c.c.C.[.[localhost].[/appged].log - Initializing Spring DispatcherServlet 'dispatcherServlet'
11-05-2020 13:30:27.742 [http-nio-8080-exec-7] INFO o.s.web.servlet.DispatcherServlet.initServletBean - Initializing Servlet 'dispatcherServlet'
11-05-2020 13:30:27.771 [http-nio-8080-exec-7] INFO o.s.web.servlet.DispatcherServlet.initServletBean - Completed initialization in 29 ms
la classe le Logging Aspect:包 com.app.ged.api.aspect;
import java.util.Arrays;
import org.aspectj.lang.JoinPoint;
import org.aspectj.lang.ProceedingJoinPoint;
import org.aspectj.lang.annotation.AfterThrowing;
import org.aspectj.lang.annotation.Around;
import org.aspectj.lang.annotation.Aspect;
import org.aspectj.lang.annotation.Pointcut;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.stereotype.Component;
/**
* Aspect for logging execution of service and repository Spring components.
*
*
*/
@Aspect
@Component
public class LoggingAspect {
private final Logger log = LoggerFactory.getLogger(this.getClass());
/**
* Pointcut that matches all repositories, services and Web REST endpoints.
*/
@Pointcut("within(@org.springframework.stereotype.Repository *)" +
" || within(@org.springframework.stereotype.Service *)" +
" || within(@org.springframework.web.bind.annotation.RestController *)")
public void springBeanPointcut() {
// Method is empty as this is just a Pointcut, the implementations are in the advices.
}
/**
* Pointcut that matches all Spring beans in the application's main packages.
*/
@Pointcut("within(com.app.ged.api.repository.*)"+
" || within(com.app.ged.api.service.*)"+
" || within(com.app.ged.api.controller.*)")
public void applicationPackagePointcut() {
// Method is empty as this is just a Pointcut, the implementations are in the advices.
}
/**
* Advice that logs methods throwing exceptions.
*
* @param joinPoint join point for advice
* @param e exception
*/
@AfterThrowing(pointcut = "applicationPackagePointcut() && springBeanPointcut()", throwing = "e")
public void logAfterThrowing(JoinPoint joinPoint, Throwable e) {
log.error("Exception in {}.{}() with cause = {}", joinPoint.getSignature().getDeclaringTypeName(),
joinPoint.getSignature().getName(), e.getCause() != null? e.getCause() : "NULL");
}
/**
* Advice that logs when a method is entered and exited.
*
* @param joinPoint join point for advice
* @return result
* @throws Throwable throws IllegalArgumentException
*/
@Around("applicationPackagePointcut() && springBeanPointcut()")
public Object logAround(ProceedingJoinPoint joinPoint) throws Throwable {
if (log.isDebugEnabled()) {
log.debug("Enter: {}.{}() with argument[s] = {}", joinPoint.getSignature().getDeclaringTypeName(),
joinPoint.getSignature().getName(), Arrays.toString(joinPoint.getArgs()));
}
try {
Object result = joinPoint.proceed();
if (log.isDebugEnabled()) {
log.debug("Exit: {}.{}() with result = {}", joinPoint.getSignature().getDeclaringTypeName(),
joinPoint.getSignature().getName(), result);
}
return result;
} catch (IllegalArgumentException e) {
log.error("Illegal argument: {} in {}.{}()", Arrays.toString(joinPoint.getArgs()),
joinPoint.getSignature().getDeclaringTypeName(), joinPoint.getSignature().getName());
throw e;
}
}
}
我的 logback-spring.xml
<?xml version="1.0" encoding="UTF-8"?>
<configuration>
<appender name="STDOUT" class="ch.qos.logback.core.ConsoleAppender">
<encoder>
<pattern>
%d{dd-MM-yyyy HH:mm:ss.SSS} [%thread] %-5level %logger{36}.%M - %msg%n
</pattern>
</encoder>
</appender>
<appender name="SAVE-TO-FILE" class="ch.qos.logback.core.FileAppender">
<file>${LOG_PATH}/log-appGed.log</file>
<encoder class="ch.qos.logback.classic.encoder.PatternLayoutEncoder">
<Pattern>
%d{dd-MM-yyyy HH:mm:ss.SSS} [%thread] %-5level %logger{36}.%M - %msg%n
</Pattern>
</encoder>
</appender>
<springProfile name="pc">
<root level="info">
<appender-ref ref="STDOUT"/>
<appender-ref ref="SAVE-TO-FILE"/>
</root>
<logger name="com.app.ged.api.controller" additivity="false" level="debug">
<appender-ref ref="STDOUT"/>
<appender-ref ref="SAVE-TO-FILE"/>
</logger>
<logger name="com.app.ged.api.service" additivity="false" level="debug">
<appender-ref ref="STDOUT"/>
<appender-ref ref="SAVE-TO-FILE"/>
</logger>
</springProfile>
<springProfile name="dev">
<root level="info">
<appender-ref ref="STDOUT"/>
<appender-ref ref="SAVE-TO-FILE"/>
</root>
<logger name="com.app.api.service" additivity="false" level="debug">
<appender-ref ref="STDOUT"/>
<appender-ref ref="SAVE-TO-FILE"/>
</logger>
</springProfile>
<springProfile name="prod">
<root level="info">
<appender-ref ref="SAVE-TO-FILE"/>
</root>
<logger name="com.app.ged.api.service" additivity="false" level="error">
<appender-ref ref="SAVE-TO-FILE"/>
</logger>
</springProfile>
</configuration>
应用程序属性
#logging
spring.profiles.active=pc
logging.path=C:/logs
解决方案
运行的活动配置文件是pc
和方面日志是 forerror
或 fordebug
pc
profile的当前根级别配置用于info
应用程序。
您可以将根日志级别设置为,debug
而不是info
如下。这是一个应用程序范围的设置
<springProfile name="pc">
<root level="debug">
<appender-ref ref="STDOUT"/>
<appender-ref ref="SAVE-TO-FILE"/>
</root>
..
</springProfile>
debug
或将方面包类的日志级别设置为
<springProfile name="pc">
<root level="info">
<appender-ref ref="STDOUT"/>
<appender-ref ref="SAVE-TO-FILE"/>
</root>
<logger name="com.app.ged.api.aspect" additivity="false" level="debug">
<appender-ref ref="STDOUT"/>
<appender-ref ref="SAVE-TO-FILE"/>
</logger>
<logger name="com.app.ged.api.controller" additivity="false" level="debug">
<appender-ref ref="STDOUT"/>
<appender-ref ref="SAVE-TO-FILE"/>
</logger>
<logger name="com.app.ged.api.service" additivity="false" level="debug">
<appender-ref ref="STDOUT"/>
<appender-ref ref="SAVE-TO-FILE"/>
</logger>
</springProfile>
推荐阅读
- jmeter - 在 URL 查询中具有值 {3D} 的 java.lang.IllegalArgumentException
- java - Ant 媒体服务器:线程“主”java.lang.UnsupportedClassVersionError 中的异常
- css - 有没有办法从另一个父文件夹 css react js 导入文件
- big-o - 如何使用 Big-O 的正式定义证明 y = n^2 不属于 O(1)?
- docker - 调整 docker swarm 模式的负载均衡器
- google-sheets - 从 Apps Script google 表格调用 BigQuery 在 BigQuery 中保存的查询
- ios - Stripe 客户端意图错误迅速:没有这样的 payment_intent
- java - 按多个字段分组的流:,管理地图嵌套地图的输出
- flutter - Flutter 中的 ReorderableListview 中无法访问 ReorderableListview.builder 和无物理属性
- c# - 创建类实例时如何将值硬编码到属性变量?