inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

스프링 핵심 원리 - 고급편

정리

실행시간에 따른 log 레벨 적용

398

이윤구

작성한 질문수 4

7

강사님께서 말씀주신 실행시간에 따른 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();
}
}

 

spring 디자인-패턴

답변 1

0

김영한

이윤구님 공유 감사합니다^^

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