실행시간에 따른 log 레벨 적용
398
작성한 질문수 4
강사님께서 말씀주신 실행시간에 따른 log 레벨 적용해 보았습니다.
필요하신 부분 참고부탁 드립니다.
(오류시에만 로그 남기는 부분은 @AfterThrowing을 사용하면 될것같습니다, - retry 에서 재시도 부분 제거)
1. 애노테이션 - 기본값 1000
@Target(ElementType.METHOD)
@Retention(RetentionPolicy.RUNTIME)
public @interface CheckTime {
int value() default 1000;
}
2. Aspect
@Around("@annotation(checkTime)")
public void checkTimer(ProceedingJoinPoint joinPoint, CheckTime checkTime) throws Throwable {
int mills = checkTime.value();
int maxMills = 4000;
StopWatch stopWatch = new StopWatch();
stopWatch.start();
joinPoint.proceed();
stopWatch.stop();
long totalTimeMillis = stopWatch.getTotalTimeMillis();
Signature signature = joinPoint.getSignature();
String methodName = signature.getName();
if (totalTimeMillis <= mills) {
log.info("methodName: {}, 실행시간 = {}ms", methodName, totalTimeMillis);
} else if (totalTimeMillis <= maxMills) {
log.warn("methodName: {}, 실행시간 = {}ms", methodName, totalTimeMillis);
} else {
log.error("methodName: {}, 실행시간 = {}ms", methodName, totalTimeMillis);
}
}
3. 애플리케이션 코드 - 랜덤으로 실행시간 적용
@CheckTime(value = 2000)
public String save(String itemId) {
seq++;
if (seq % 5 == 0) {
throw new IllegalStateException("예외 발생");
}
sleep();
return "ok";
}
private void sleep() {
int[] ints = {1000, 2000,3000,4000,5000};
double random= Math.random();
int num = (int) Math.round(random * (ints.length-1));
System.out.println(ints[num]);
try {
Thread.sleep(ints[num]);
} catch (InterruptedException e) {
e.printStackTrace();
}
}
답변 1
SpringBoot 4.0.6 버전에서 PackageLogTracePostProcessor exception
0
39
2
어드바이스 순서 디폴트 기준이 궁금합니다.
0
67
1
AspectV1 예제를 @Configuration 수동 등록으로도 가능한가요?
0
96
2
구체 클래스를 상속받아 확장한 형태도 클래스패턴/데코레이터 패턴이라고 칭하나요?
0
67
1
TraceTemplate 을 미리 빈으로 등록해서 사용할때 이렇게 설정하는게 맞는건가요?
0
60
1
Decorator 에서 추상메서드로 뺄때 질문 있습니다.
0
59
1
대상 클래스에 기본 생성자가 없을 때
0
80
1
스프링 부트 버전 4.0 aop 의존성 명칭 변경
1
392
2
final 키워드 사용 관련 질문
0
82
1
안녕하세요
0
72
1
ThradLocal 실무 사례
0
103
2
실무에서의 동시성 문제
0
70
1
로그 등 부가 기능에 대한 테스트코드
0
56
1
ProceedingJoinPoint와 MethodInvocation에 대하여
0
73
1
실무 멀티스레딩에 대한 궁금증
0
75
1
안녕하세요 질문있습니다
0
47
1
AspectV3 aop 실행 순서 문의 드립니다
0
43
1
MDC vs AOP 중에 고민중입니다.
0
82
1
순환참조
0
165
2
this를 단독으로 사용할때랑 파라미터 바인딩 할때 차이
0
83
1
빈 후처리에 등록 질문 있습니다.
0
84
1
AppConfig 설정하는 설명중에 이해가 안되는게 있습니다.
0
97
1
ThreadLocal을 지역변수로 선언하면 remove가 필요할까요?
0
121
2
@Aspect 어노테이션으로 생성된 Advisor의 Bean 저장 여부
0
75
1





