1. AOP가 필요한 상황

Ex. 모든 메서드의 호출 시간을 측정하고 싶다면?



  • MemberService 회원가입 시간 측정
public Long join(Member member) {
    
    long start = System.currentTimeMillis();
    
    try {
        validateDuplicateMember(member); //중복 회원 검증
 		memberRepository.save(member);
 		return member.getId();
 	}finally {
 		long finish = System.currentTimeMillis();
 		long timeMs = finish - start;
 		System.out.println("join " + timeMs + "ms");
 	}
 }
  • 문제
    • 시간을 측정하는 기능은 핵심 관심 사항x, 공통 관심 사항o
    • 핵심 로직에 시간 측정 로직을 추가하여 유지보수가 어려워 졌다.
    • 시간을 측정하는 로직을 변경할 때 모든 로직을 찾아가면서 변경해야 한다.

2. AOP 적용

시간 측정 AOP 등록

  • AOP: Aspect Oriented Programming

    • 공통 관심 사항과 핵심 관심 사항을 분리


  • aop/TimeTraceAop.java

@Component
@Aspect
public class TimeTraceAop {

    @Around("execution(* com.example.practice1..*(..))")
    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");
       }
    }
}
  • 코드 설명
    • @Component: 컴포넌트 스캔 방식으로 스프링 빈으로 등록
    • @Aspect: 공통 관심사항을 모듈화(Aspect), 이 코드가 Aspect임을 명시
    • @Around: com.example.practice1아래 패키지 경로의 모든 메서드에 이 Aspect를 적용
    • ProceedingJoinPoint: 클라이언트가 호출한 모든 비지니스 메서드

  • 문제해결
    • 회원가입, 회원조회 등 핵심 관심사항과 공통 관심 사항을 분리한다.
    • 핵심 관심 사항을 평소 같이 유지 할 수 있다.
    • 공통 관심 사항 적용 대상을 선택할 수 있다.

동작 원리

  • AOP 적용 전 의존 관계


  • AOP 적용 후 의존 관계
    • @Around로 지정된 AOP적용 대상들을 스프링이 proxy라는 가짜 스프링빈으로 등록한다.
    • joinPoint.proceed()를 호출하면 실제 memberService가 호출된다.
profile
화이팅!

0개의 댓글

관련 채용 정보