AOP

    AOP: Aspect Oriented Programming (관점 지향 프로그래밍)

     

     

    AOP 가 필요한 상황 가정

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

    AOP 적용 전

     

    ⚠️ 문제

    • 회원가입, 회원 조회에 시간을 측정하는 기능은 핵심 관심 사항이 아님
    • 시간을 측정하는 로직은 공통 관심 사항
    • 시간을 측정하는 로직과 핵심 비즈니스의 로직이 섞여서 유지보수가 어려움
    • 시간을 측정하는 로직을 별도의 공통 로직으로 만들기 매우 어려움
    • 시간을 측정하는 로직을 변경할 때 모든 로직을 찾아가면서 변경해야 함

     

     

    AOP 적용

     

    • AOP 패키지 생성 - TimeTraceAop.java
      • @Aspect
      • @Component
      • @Around

     

    ✔️ 해결

    • 공통 관심 사항(cross-cutting concern) vs 핵심 관심 사항(core concern) 분리
    • 회원가입, 회원 조회등 핵심 관심사항과 시간을 측정하는 공통 관심 사항을 분리
    • 시간을 측정하는 로직을 별도의 공통 로직으로 생성
    • 핵심 관심 사항을 깔끔하게 유지 가능
    • 변경이 필요하면 이 로직만 변경하면 됨
    • 원하는 적용 대상 선택 가능 (@Around)

     

    스프링의 AOP 동작 방식

     

     

    ✔️ 스프링 컨테이너가 프록시를 생성하여 프록시에서 AOP를 실행하고, jointPoint.proceed()하면 실제 memberService 호출

    + Recent posts