본문 바로가기
Spring

[Spring] AOP(Aspect Oriented Programming)

by jelliclesu 2024. 9. 12.

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 호출