꼬물꼬물
AOP 본문
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)만 변경할 수 있다.
- 원하는 적용 대상을 선택할 수 있다.
프록시 방식의 AOP
'스터디 > 스프링 입문' 카테고리의 다른 글
스프링 DB 접근 기술 (0) | 2022.08.29 |
---|---|
회원 관리 예제 - 웹 MVC 개발 (0) | 2022.08.29 |
스프링 빈과 의존관계 (0) | 2022.08.28 |
회원 관리 예제 (0) | 2022.08.28 |
스프링 웹 개발 기초 (0) | 2022.08.27 |