Spring
[Spring] AOP(Aspect Oriented Programming)
jelliclesu
2024. 9. 12. 19:50
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 호출