꼬물꼬물

AOP 본문

스터디/스프링 입문

AOP

멩주 2022. 8. 30. 04:30

AOP가 필요한 상황

- 모든 메소드의 호출 시간을 측정하고 싶다면?

- 공통 관심 사항(cross-cutting concern) vs 핵심 관심 사항(core concern)

- 회원 가입 시간, 회원 조회 시간을 측정하고 싶다면?

 

시간측정 - 공통 관심 사항

비즈니스 로직 - 핵심 관심 사항

 

공통과 핵심 관심사항이 함께 있어 유지보수가 어렵다.

시간을 변경할 때, 모든 로직을 찾아가 변경하기 어렵다.

AOP 적용

AOP(Aspect Oriented Programming)

- 공통 관심 사항과 핵심 관심 사항의 분리

aop/TimeTrace.class

@Aspect
@Component
public class TimeTraceAop {

    @Around("execution(* hello.hellospring..*(..))") // hello.hellospring 패키지 하위의 모든 것을 하겠다
    public Object execute(ProceedingJoinPoint joinPoint) throws Throwable {
        long start = System.currentTimeMillis();
        System.out.println("START: "+joinPoint.toString());
        try{
            return joinPoint.proceed();
        }finally {
            long finish = System.currentTimeMillis();
            long timeMs = finish - start;
            System.out.println("END: "+joinPoint.toString()+" "+timeMs+"ms");
        }
    }
}

중간에 intercept해서 로직을 구현하는 것이 AOP

 

- 핵심 관심 사항을 깔끔하게 유지

- 변경이 필요하면 공통관심사항(timetrace)만 변경할 수 있다.

- 원하는 적용 대상을 선택할 수 있다.

 

 

프록시를 먼저 사용하게 된다.
Enhancer..

프록시 방식의 AOP

 

 

'스터디 > 스프링 입문' 카테고리의 다른 글

스프링 DB 접근 기술  (0) 2022.08.29
회원 관리 예제 - 웹 MVC 개발  (0) 2022.08.29
스프링 빈과 의존관계  (0) 2022.08.28
회원 관리 예제  (0) 2022.08.28
스프링 웹 개발 기초  (0) 2022.08.27