프로젝트를 구현하면서 핵심적인 기능을 구현하는 핵심로직(core-concern)과
부가적으로 사용되는 로깅, 성능측정, 트래픽 체크 등등의 공통로직(cross-cutting concern)이 존재한다.
AOP (Aspect Oriented Programming)
각 관점을 기준으로 로직을 모듈화한다는 것은 코드들을 부분적으로 나누어서 모듈화하겠다는 의미다.
이때, 소스 코드상에서 다른 부분에 계속 반복해서 쓰는 코드들을 발견할 수 있는데
이것을 흩어진 관심사 (Crosscutting Concerns)라 부른다.
AOP는 프로젝트 전반에 흩어져있는 공통사용 로직을 분리하여 한번만 정의 후 재사용하는 기술을 말한다.
AOP 주요 개념
- Aspect : 위에서 설명한 흩어진 관심사를 모듈화 한 것. 주로 부가기능을 모듈화함.
- Target : Aspect를 적용하는 곳 (클래스, 메서드 .. )
- Advice : 실질적으로 어떤 일을 해야할 지에 대한 것, 실질적인 부가기능을 담은 구현체
- JointPoint : Advice가 적용될 위치, 끼어들 수 있는 지점. 메서드 진입 지점, 생성자 호출 시점, 필드에서 값을 꺼내올 때 등 다양한 시점에 적용가능
- PointCut : JointPoint의 상세한 스펙을 정의한 것. 'A란 메서드의 진입 시점에 호출할 것'과 같이 더욱 구체적으로 Advice가 실행될 지점을 정할 수 있음
의존성 추가
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-aop</artifactId>
</dependency>
@AOP 사용을 위해서는 위와같이 의존성을 추가해준다.
시간측정을 위한 AOP를 구현해보자
aop. TimeTraceAop 작성
package com.example.intro.aop;
import org.aspectj.lang.ProceedingJoinPoint;
import org.aspectj.lang.annotation.Around;
import org.aspectj.lang.annotation.Aspect;
import org.springframework.stereotype.Component;
@Aspect
@Component
public class TimeTraceAop {
@Around("execution(* com.example.intro..*(..))")
public Object execute(ProceedingJoinPoint joinpoint) throws Throwable{
long start = System.currentTimeMillis();
System.out.println("START : " + joinpoint.toString());
try {
return joinpoint.proceed();
}finally {
long fin = System.currentTimeMillis();
long timeMs = fin -start;
System.out.println("END : " + joinpoint.toString() +" " + timeMs+"ms");
}
}
}
컴포넌트 자동스캔으로 빈에 등록해주었고,
@Around를 통해 원하는 대상을 지정해주었다 (명시된 패키지 레벨 및 모든 실행단위별로 적용이 되게 하였다.)
동작원리
Aop는 동작시 프록시서버를 이용한다.
실제 코드마다 aop를 적용시키기 위해 프록시 컨테이너를 만들어서 실제 컨테이너에 주입한다.
지금까지 Spring Boot에서 사용되는 다양한 개념들에 대해서
아주 얕게나마 코딩해보면서 공부하였다.
개념들을 이해하는데 큰 도움이 되는 강의였고,
Spring DB연동기술이 어떻게 발전해왔는지를 볼 수 있어서 좋았다.
말 그대로 작은 길잡이 역할을 하기에 좋은 입문강의였다.
전체코드 : https://github.com/bangbangu4/Spring-intro
'Study > Java Spring Boot' 카테고리의 다른 글
[Spring] 핵심 원리 2-1 회원 도메인 개발과 테스트 (0) | 2022.02.04 |
---|---|
[Spring] 핵심 원리 1 객체지향 설계와 스프링(SOLID) (0) | 2022.02.04 |
[Spring] 스프링 입문6 - DB 접근기술(JDBC, JdbcTemplate, JPA, SpringJpa) (0) | 2022.01.14 |
[Spring] 스프링 입문5 - 회원 웹 화면 (0) | 2022.01.14 |
[Spring] 스프링 입문4 - Bean 등록법 (0) | 2022.01.14 |