SpringBoot 收集并记录接口调用过程信息的Aop实践

本文介绍了如何使用SpringBoot的Aop功能,通过自定义注解@ApiInvokeRecord来记录接口调用的详细信息,包括URI、调用方、提供方、入参、响应状态和异常日志。在Controller层的方法上应用该注解,即可触发AOP的前置、返回和异常通知,将信息保存至数据库。
摘要由CSDN通过智能技术生成
1 需求拆解

博文将始终围绕着一个Target进行论述:如何记录接口处理过程的URI、接口调用方、接口提供方、入参、接口响应状态(即成功或失败)以及异常日志。

  • 可以借助Spring AOP 实现。
  • 思路:自定义注解,此处记为 @ApiInvokeRecord。那么只要Controller层的method标注了 @ApiInvokeRecord,将会触发 AOP 处理,将接口调用过程信息记录下来,保存至DataBase。
  • 步骤细化:前置通知 负责收集 接口调用方、接口提供方、接口URL、处理时间、参数列表 这5个数据项,返回通知异常通知 负责收集接口的响应状态和异常信息。
2 自定义注解 @ApiInvokeRecord
  • @ApiInvokeRecord 作用:手动指定接口调用方和接口提供方。

@Target({
   ElementType.METHOD})
@Retention(RetentionPolicy.RUNTIME)
public @interface ApiInvokeRecord {
   

  /**
   * 接口调用方。例如  InvokeSourceEnum.MICRO_SERVICE_A
   *
   * @see com.itbounds.dev.apiinvokelog.common.enums.InvokeSourceEnum
   */
  InvokeSourceEnum caller();

  /**
   * 接口提供方。例如 InvokeSourceEnum.MICRO_SERVICE_B
   *
   * @see com.itbounds.dev.apiinvokelog.common.enums.InvokeSourceEnum
   */
  InvokeSourceEnum callee() default InvokeSourceEnum.MICRO_SERVICE_B;

}

3 定义切面 ApiInvokeAspect
3.1 Maven Dependency
    <dependency>
      <groupId>org.springframework.boot</groupId>
      <artifactId>spring-boot-starter-aop</artifactId>
    </dependency>
3.2 @EnableAspectJAutoProxy 开启Aop
@SpringBootApplication
@EnableAspectJAutoProxy
public class ApiInvokeLogApplication {
   

  public static void main(String[] args) {
   
    SpringApplication.run(ApiInvokeLogApplication.class, args);
  }

}
3.3 定义切面 ApiInvokeAspect

/**
 * @Description 接口调用切面定义
 * @Author blake
 * @Date 2019/9/29 2:37 下午
 * @Version 1.0
 */
@Component
@Aspect
@Slf4j
public class 
  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值