[Spring][인프런 스프링 입문] AOP가 필요한 상황 및 적용

2023. 1. 6. 12:00·공부/Spring
728x90

본 포스팅은 김영한 강사님의 인프런 강의 "스프링 입문"을 정리한 포스팅으로 강의 자료에서 사용한 자료를 사용했음을 밝힙니다.

https://www.inflearn.com/course/%EC%8A%A4%ED%94%84%EB%A7%81-%EC%9E%85%EB%AC%B8-%EC%8A%A4%ED%94%84%EB%A7%81%EB%B6%80%ED%8A%B8/dashboard

 

[무료] 스프링 입문 - 코드로 배우는 스프링 부트, 웹 MVC, DB 접근 기술 - 인프런 | 강의

스프링 입문자가 예제를 만들어가면서 스프링 웹 애플리케이션 개발 전반을 빠르게 학습할 수 있습니다., - 강의 소개 | 인프런...

www.inflearn.com

 

수백개의 메소드가 있고 각각의 메소드마다 실행 시간을 알고싶다고 하자.

 

메소드가 시작할 때와 끝날 때의 시간의 차이를 계산하면 실행 시간을 알 수가 있다.

 

그러나 모든 메소드에 이러한 코드를 작성하면 유지보수도 어려워지고 많은 시간이 걸릴 것이다.

 

이럴 때 필요한 기술이 AOP(관점 지향 프로그래밍)이다.

 

AOP는 공통 관심 사항과 핵심 관심 사항을 분리하는 것이 필요하다.

 

위의 예시의 경우 메소드 실행 시간을 구하는 것을 공통 관심 사항으로 분리한 뒤 원하는 곳마다 적용시키면 된다.

 

aop라는 패키지를 만들고 그 안에 시간을 측정하는 TimeTraceAop 클래스를 생성했다.

@Aspect
@Component
public class TimeTraceAop {

    @Around("execution(* hello.hellospring..*(..))")
    public Object execute(ProceedingJoinPoint joinPoint)throws Throwable{
        long start = System.currentTimeMillis();
        System.out.println(joinPoint.toString());
        try{
            return joinPoint.proceed();
        }finally{
            long end = System.currentTimeMillis();
            long time = end-start;
            System.out.println(joinPoint.toString()+" : "+time);

        }
    }
}

 

  1. @Aspect : 해당 클래스가 공통적으로 적용할 클래스임을 알려줌.
  2. @Component : 컴포넌트 스캔으로 스프링 빈에 등록. 이 방법 대신 직접 스프링 빈에 등록해도 됨.
  3. @Around : 안에 point cut 표현식을 사용하여 공통적으로 적용할 메소드의 범위를 지정할 수 있다.
  4. joinPoint.toString() : 어떠한 메소드를 실행했는지 알려줌.
  5. joinPoint.proceed() : 다음 메소드를 실행하고 결과를 반환한다.

 

AOP를 적용하게 되면 프록시를 만들고 프록시를 통해서 AOP를 실행하고 joinPoint.proceed()가 실행되면 실제가 호출된다.

 

DI(dependency injection)으로 구현했기 때문에 이러한 것이 가능하다.

728x90

'공부 > Spring' 카테고리의 다른 글

[Spring][스프링 핵심 원리] 스프링 컨테이너와 스프링  (0) 2023.01.12
[InteliiJ] 인텔리제이 단축키  (2) 2023.01.10
[Spring][인프런 스프링 입문] Test 코드 작성  (0) 2023.01.02
[Spring][인프런 스프링 입문] JPA 기본 사용법  (2) 2023.01.01
[Spring][인프런 스프링 입문] JdbcTemplate 사용법  (0) 2022.12.31
'공부/Spring' 카테고리의 다른 글
  • [Spring][스프링 핵심 원리] 스프링 컨테이너와 스프링
  • [InteliiJ] 인텔리제이 단축키
  • [Spring][인프런 스프링 입문] Test 코드 작성
  • [Spring][인프런 스프링 입문] JPA 기본 사용법
웅대
웅대
알고리즘과 백엔드를 중심으로 열심히 공부 중입니다! 같이 소통하며 공부해요!
    250x250
  • 웅대
    웅대 개발 블로그
    웅대
  • 전체
    오늘
    어제
    • 분류 전체보기
      • 백준 알고리즘
        • dp
        • 문자열
        • 정렬
        • 스택
        • 브루트 포스
        • 이진 탐색
        • 정리
        • 우선순위 큐
        • 자료구조
        • 그래프
        • 기타
        • 그리디
      • 컴퓨터 언어
        • Kotlin
        • Python
        • C#
      • 공부
        • Database
        • Android Studio
        • Algorithm
        • 컴퓨터 구조론
        • Spring
        • lombok
        • AWS
        • Network
        • OS
        • Git & GitHub
        • AI
        • Computer Vision
        • 보안
        • Nginx
        • 프론트
        • express
        • GCP
        • grokking concurrency
        • DevOps
  • 블로그 메뉴

    • 홈
    • 태그
    • 방명록
  • 링크

  • 공지사항

  • 인기 글

  • 태그

    parametric search
    ChatPromptTemplate
    bfs
    Vector Store
    binary search
    codetree
    Merge
    influxDB CLI
    스택
    nn.RNN
    푸쉬 알람
    openvidu 배포
    ci/cd
    다익스트라
    파이썬
    스프링 OAuth2
    code tree
    embedding
    RNN
    AWS Lambda
  • 최근 댓글

  • 최근 글

  • hELLO· Designed By정상우.v4.10.3
웅대
[Spring][인프런 스프링 입문] AOP가 필요한 상황 및 적용
상단으로

티스토리툴바