【AOP系列】2.性能监控

博客介绍了在Java中利用Spring AOP和自定义注解进行性能监控的方法。先创建自定义注解标记需监控的方法,再创建切面处理标记注解的方法,最后在方法上添加注解,调用方法时触发切面方法实现统一监控。

在Java中,我们可以使用Spring AOP(面向切面编程)和自定义注解来做性能监控。以下是一个简单的示例:

首先,我们创建一个自定义注解,用于标记需要监控性能的方法:

import java.lang.annotation.ElementType;
import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;
import java.lang.annotation.Target;

@Target(ElementType.METHOD) //注解放置的目标位置,METHOD是可放在方法级别
@Retention(RetentionPolicy.RUNTIME) //注解在哪个阶段执行
public @interface PerformanceMonitor {
    String value() default ""; //注解的值
}

然后,我们创建一个切面,用于处理标记了@PerformanceMonitor的方法:

import org.aspectj.lang.ProceedingJoinPoint;
import org.aspectj.lang.annotation.Around;
import org.aspectj.lang.annotation.Aspect;
import org.aspectj.lang.annotation.Pointcut;
import org.springframework.stereotype.Component;

@Aspect
@Component
public class PerformanceAspect {

    @Pointcut("@annotation(com.yourpackage.PerformanceMonitor)") //指定自定义注解的路径
    public void pointcut() {}

    @Around("pointcut()")
    public Object around(ProceedingJoinPoint joinPoint) {
        Object result = null;
        long startTime = System.currentTimeMillis();
        try {
            result = joinPoint.proceed(); //执行方法
        } catch (Throwable e) {
            e.printStackTrace();
        }
        long endTime = System.currentTimeMillis();
        System.out.println("方法执行时间:" + (endTime - startTime) + "ms");
        return result;
    }
}

最后,我们在需要监控性能的方法上添加@PerformanceMonitor注解:

public class SomeService {

    @PerformanceMonitor("执行某个操作")
    public void someMethod() {
        //...
    }
}

这样,当someMethod方法被调用时,PerformanceAspect中的around方法会被触发,从而实现性能的统一监控。

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值