기본 콘텐츠로 건너뛰기

[Spring] AOP를 알아보자

이번 시간에는 AOP라는 것에 대해 다뤄보려한다.
실무에선 거의 사용되지 않는 것이지만 회사 면접 등에서 물어 볼 수 있으니 이론 위주로 설명하려한다.

인트로
구현하고자 하는 비즈니스 로직과 다소 거리가 있거나 여러 모듈에 걸쳐 공통적이고 반복적으로 필요로 하는
처리 내용을 횡단 관심사라 한다.
보안, 로깅, 트랜젝션관리, 모니터링, 캐시처리, 예외처리 등등이 이에 해당한다.
횡단 관심사에 해당 하는 부분을 분리해 한 곳으로 모으는 것을 ‘횡단 관심사의 분리' 라고 하고
이를 실행하는 방법을 ‘관점지향 프로그래밍'이라 한다.


AOP 개요
AOP를 활용하면 애플리케이션 코드에서 공통적인 기능을 분리해 낼 수 있다.


AOP 용어
  • Aspect : AOP의 단위가 되는 횡단 관심사에 해당. ex) 로그를 출력한다. 예외를 처리한다 등
  • JoinPoint : 횡단 관심사가 실행될 지점이나 시점. 스프링에선 메서드 단위로 조인포인트를 잡는다.
  • Advice : 특정 조인 포인트에서 실행되는 코드. 횡단 관심사를 실제 구현해 처리하는 부분.
  • Pointcut : 수많은 조인 포인트 중에 실제로 어드바이스를 적용할 곳을 선별하기 위한 표현식. 조인 포인트의 구룹.
  • Weaving : 애플리케이션 코드의 적절한 지점에 애스팩트를 적용하는 것을 말함.
  • Target  : AOP 처리에 의해 처리 흐름에 변화가 생긴 객체를 말함.


스프링에서 지원하는 어드바이스 유형
  • Before : 조인 포인트 전에 실행된다. 예외 발생하는 경우 제외하고 항상 실행됨.
  • After Returning : 조인 포인트가 정상적으로 종료한 후 실행.
  • After Throwing : 조인 포인트에서 예외가 발생했을 때 실행
  • After : 조인 포인트 처리 완료 후 실행.
  • Around : 조인 포인트 전 후에 실행


스프링 AOP
스프링 프레임 워크 안에 스프링 AOP가 포함돼 있다. 스프링 AOP에는 DI 컨테이너에서 관리하는 빈들을 타깃으로
어드바이스를 적용하는 기능이 있는데, 조인 포인트에 어드바이스를 적용하는 방법은 프락시 객체를 만들어
대체하는 방법을 쓴다.
어드바이스가 적용된 이후 DI 컨테이너에서 빈을 꺼내면 프락시 형태로 어드바이스 기능이 덮혀진 빈이 나온다.


애스팩트를 동작시키려면 자바기반 설정방식에서 설정 클래스에 @CnableAspectJAutoProxy를 추가해야 한다.

@SpringBootApplication
@EnableAspectJAutoProxy
public class JboardApplication {

 @Bean
 public MyUtil myUtil() {
    return new MyUtil();
 }

 public static void main(String[] args) {
    SpringApplication.run(JboardApplication.class, args);
 }
}


XML 기반설정으로는 <aop:aspectj-autoproxy/>를 추가해 줘야 한다.


자바 기반 설정 방식에서의 어드바이스 정의
어드바이스 기능을 하는 메서드에 @Before 애너테이션을 붙인 다음, 포인트컷 표현식을 추가해 주면 된다.
메서드의 매개 변수로 JoinPoint를 선언하고 있는데, 매서드가 호출 될 때 전달 되는 인수를 통해
실행중인 매서드의 정보를 구할 수 있다.

@Aspect
@Component
public class MethodStartLoggingAspect {
  @Before("execution(* *..*ServiceImpl.*(..))")
  public void startLog(JoinPoint jp) {}
}
xml로도 설정하는 방법이 있다. xml 방식은 직접 다루진 않겟다.


스프링 프로젝트에서 활용되는 AOP 기능
1. 트랜잭션 관리
트랜젝션 관리가 필요한 메서드에 @Transactional 애너테이션을 지정하면 스프링 프레임워크가 대신
트랜젝션 관리를 해준다. 스프링 프레임워크에서 해당 메서드가 정상 종료한 것이 확인 되면 커밋 하고,
실패하면 롤백 한다.


2. 인가
권한 제어가 필요한 메서드에 @PreAuthrize를 지정하면 메서드 호출 전 특정 인가 조건을 만족하는지 확인할 수 있다. @PreAuthrize(“hasRole(‘ADMIN’)”) 메서드 사용자가 관리자인지 확인


3. 캐싱
메서드에 @Cacheable을 지정하면 메서드의 매개변수 등을 키로 사용해 메서드의 실행 결과를 캐시로 관리 할 수 있다. 캐시에 키가 있는 메서드를 호출하면 캐시에 등록된 반환값을 돌려준다. @Cachable(“user”)


4. 비동기 처리
비동기 처리가 하고 싶다면 @Async 애너테이션을 붙여준다. 이는 별도의 스래드에서 실행될 수 있다.
반환값은 CompletableFuture or DeferredResult 타입이어야 한다.


5. 재처리
@Retryable을 붙여주면 된다.


데이터 바인딩과 형변환

자바 객체의 프로퍼티에 외부에서 입력된 값을 설정하는 과정을 데이터 바인딩이라 한다.
데이터 바인딩 형변환이 없다면  웹 애플리케이션에서 요청 파라미터를 받아 올 때
HttpServletRequest 인터페이스의 getParameter 메서드를 사용해야 하는데,
여간 불편한 과정을 거처야 햔다. 스프링은 이런 형 변환을 제공한다.

이외 리소스 관리 메세지 관리 등등이 있지만 이번 절에선 여기까지 다뤄 보겠다

그럼 끝~!!

댓글

이 블로그의 인기 게시물

[자바 웹 프로그래밍]2장 문자열 계산기 구현을 통한 테스트와 리펙토링

이번엔 2장에 나와 있는 내용 정리와 느낀점을 정리 해 보겠다. 1. main() 메소드를 활용한 테스트의 문제점.   - 소스코드 구현 후 정상적으로 동작하는지 확인 위해 일반적인 방법은 main()메소드를 활용하는 것이다.   - 실제 서비스를 담당하는 프로덕션 코드와 이 프로덕션 코드가 정상 동작 하는지 확인을 위한 main() 으로 나뉜다.   - 이 방법의 첫번째 문제점은 프로덕션코드와 main() 메서드가 함께 있다는 것이다.   - 프로덕션 코드와 테스트코드(main)을 분리할 수 있다.   - 두 번째 문제는 내가 구현하고 있는 메서드만 집중 할 수 없고, 클래스가 가지고 있는 모든 메서드를 테스트 할 수 밖에 없다.   - 다른 문제는 항상 콘솔로 확인을 할 수 밖에 없다는 것이다.   - 이를 위해 등장한 라이브러리가 JUnit 이다. 내 관심을 가지는 메서드에 대해 테스트 가능하다. 2. JUnit을 활용해 main() 메서드 문제 극복 2.1 한 번에 메서드 하나에만 집중.   - JUnit관련 라이브러리 추가 후  테스트 메서드에 @Test를 붙이면 된다.   - test 관련 코드 작성 후 Run > Run as> JunitTest를 실행해 보자.   - 각각 테스트 메서드를 독립적으로 실행할 수 있기 때문에 현재 내가 구현하고 있는 프로덕션 코드의 메서드에 집중할 수 있다. import org.junit.Test; public class CalculatorTest { @Test public void add() { Calculator cal = new Calculator(); System.out.println(cal.add(1,2)); } } 2.2 결과 값을 눈이 아닌 프로그램을 통해 자동화 import org.junit.Test; import static org.junit.Assert.assertEquals;

[고량주] 라오왕 연태고량주 플러스

나에게 처음 고량주란 이런것이다 라는걸 알려준 녀석이다. 부모님이 중국집을 하다 보니 가끔 초록색병 고량주를 먹었을때  역한 공업용 알콜 맛에 고량주는 나랑 안맞는다 생각했다가 우연히 양고기에 이녀석을 접한 뒤로 고량주의 맛을 알아버렸다... 제품명 : 라오왕 연태고량주플러스 제품유형 : 일반증류주 도수 : 34.2% 가격 : 9000원(홈플러스 익스프레스 기준) 재구매 의사 : 있다 시음평 : 역시 고량주 특유의 향인데, 열대과일 향도나고, 배향, 살짝 달달한 향이 난다.            목넘김은 34.2%에도 불구하고 그리 힘들지 않았다(주당이 된걸수도..)             중국요리나 양꼬치집에서 맛있는 술이 땡긴다면 강력추천한다.