zoukankan      html  css  js  c++  java
  • spring统计接口访问时长(转)

    转自:https://blog.csdn.net/lengyue309/article/details/82020420

     接口开发完以后,对其进行统计十分必要,监控接口的访问时长可以发现哪些接口需要优化,统计接口的访问次数可以发现哪些接口最受欢迎。

    下面通过使用aop实现了一个简单的统计功能

    @Slf4j
    @Component
    @Aspect
    public class ApiVisitStatistics {
    
        //统计请求的处理时间,每个线程是独立的
        ThreadLocal<Long> startTime = new ThreadLocal<>();
        //整个服务是唯一的
        public static final Map<String, Long> map = new ConcurrentHashMap<>();
    
        /**
         * 定义切面
         * - 此处代表com.example.api.client.controller包下的所有接口都会被统计
         */
        @Pointcut("execution(* com.example.api.client.controller..*.*(..))")
        public void pointCut() {
    
        }
    
        /**
         * 在接口原有的方法执行前,将会首先执行此处的代码
         */
        @Before("pointCut()")
        public void doBefore(JoinPoint joinPoint) throws Throwable {
            startTime.set(System.currentTimeMillis());
            //获取传入目标方法的参数
            Object[] args = joinPoint.getArgs();
            String className= joinPoint.getSignature().getDeclaringType().getSimpleName();
            String methodName=joinPoint.getSignature().getName();
            String key = className + "." + methodName;
            //计数:如果不存在key,就设置为0,如果存在就在基础上加1
            map.computeIfAbsent(key, s -> 0L);
            map.computeIfPresent(key, (s, aLong) -> aLong+1);
    
    
            //接收到请求,记录请求内容
            ServletRequestAttributes attributes = (ServletRequestAttributes) RequestContextHolder.getRequestAttributes();
            HttpServletRequest request = attributes.getRequest();
            //记录请求的内容
            log.info("Aspect_URL:" + request.getRequestURL().toString());
            log.info("Aspect_Method:" + request.getMethod());
            log.info("Api访问次数:"+key+"="+map.get(key));
        }
    
        /**
         * 只有正常返回才会执行此方法
         * 记录接口访问时长
         */
        @AfterReturning(returning = "returnVal", pointcut = "pointCut()")
        public void doAfterReturning(JoinPoint joinPoint, Object returnVal) {
            HttpServletRequest request = ((ServletRequestAttributes) RequestContextHolder.getRequestAttributes()).getRequest();
            log.info("方法执行时间:" + (System.currentTimeMillis() - startTime.get()));
            log.info("方法返回值:" + JSON.toJSONString(returnVal));
    
        }
    
        /**
         * 当接口报错时执行此方法
         */
        @AfterThrowing(pointcut = "pointCut()")
        public void doAfterThrowing(JoinPoint joinPoint) {
            HttpServletRequest request = ((ServletRequestAttributes) RequestContextHolder.getRequestAttributes()).getRequest();
            log.info("接口访问失败,URI:[{}], 耗费时间:[{}] ms", request.getRequestURI(), System.currentTimeMillis() - startTime.get());
    
        }
    }
  • 相关阅读:
    牛客网在线编程:不要二
    牛客网在线编程:素数对
    剑指offer5:用两个栈实现队列
    剑指offer4:重建二叉树
    剑指offer3:从尾到头打印链表
    剑指offer2:替换空格
    剑指offer1:二维数组中的查找
    牛客网在线编程:藏宝图
    已知两个链表head1 和head2 各自有序,请把它们合并成一个链表依然有序
    回文函数的编写
  • 原文地址:https://www.cnblogs.com/wangbin2188/p/15210825.html
Copyright © 2011-2022 走看看