전체 글 554

@Target, @Retention

ElementType.ㅇ어노테이션을 만들 때 사용하는 어노테이션들이다. 어노테이션을 이용한 포인트컷을 구현할 때 등장했으며 궁금하기때문에 포스팅으로 남긴다. 구글링해보니 그렇게 어려운 내용은 아니었다. @Target @Target은 자신이 만든 어노테이션이 사용되게 될 자바 요소를 지정할 수 있다. Target의 속성으로는 ElementType.ANNOTATION_TYPE ElementType.CONSTRUCTOR ElementType.FIELD ElementType.LOCAL_VARIABLE ElementType..METHOD ElementType.PACKAGE ElementType.PARAMETER ElementType.TYPE 이렇게 여덟가지이다. 내가 주로 사용하게될 타겟은 메서드로 보인다. 메서..

Spring/Spring 2022.01.24

스프링 AOP - 실전 예제

이 포스팅은 인프런 김영한 님의 스프링 핵심 원리 고급 편을 보고 각색한 포스팅입니다. 자세한 내용은 강의를 확인해주세요 지금까지 학습한 내용을 활용해서 유용한 스프링 AOP를 만들어보자 1. @Trace 어노테이션으로 로그 출력하기 2. @Retry 어노테이션으로 예외 발생시 재시도 하기 cf) 어? 예외 발생시 재시도 하는 로직이 왜 필요하지? 예를 들어서 API통신을 하는데 조회를 해야한다고 가정해보자 특정 시간대 혹은 특정 횟수에 한번꼴로 예외가 터지는 경우라고 생각했을 때 조회라면 예외를 무시하고 다시 재시도 하면 되는 경우가 많다. 때문에 예외 로그가 찍히는 상황을 방지하고자 조회로직에 한해서 예외 발생시 재시도 하는 로직을 만드는 것이다. 먼저 어노테이션을 만들어야한다. Trace.java ..

Spring/Spring 2022.01.24

스프링 AOP - 포인트컷

이 포스팅은 인프런 김영한 님의 스프링 핵심 원리 고급 편을 보고 각색한 포스팅입니다. 자세한 내용은 강의를 확인해주세요 지금부터 포인트컷 표현식을 포함한 포인트컷에 대해서 알아보자 스프링AOP에서 제공하는 포인트컷은 꽤 많다. 1. execution 2. within 3. args 4. this 5. target 6. @target 7. @within 8. @annotation 9. @args 10. bean 우리는 이중에서 자주 사용되는 1. execution, 8. @annotation에 대해서 알아볼 것이다. execution 먼저 execution의 문법을 살펴보자 execution은 메서드 실행 조인 포인트를 매칭하기 때문에 메서드의 정보를 적어준다. execution(접근제어자? 반환타입 선..

Spring/Spring 2022.01.24

@Aspect

이 포스팅은 인프런 김영한 님의 스프링 핵심 원리 고급 편을 보고 각색한 포스팅입니다. 자세한 내용은 강의를 확인해주세요 스프링은 @Aspect 어노테이션으로 매우 편리하게 포인트컷과 어드바이스로 구성되어 있는 어드바이저 생성 기능을 지원한다. 바로 사용방법을 알아보자 1. 사용할 클래스에 @Aspect를 붙여준다. 2. 적용할 Advice에 @Around를 붙여준다 Around는 포인트컷이 된다. 3. 반환 타입은 Object 인자값으로 ProceedingJoinPoint를 넣어서 Advice로직을 만든다. 이어서 @Aspect를 어드바이저로 변환해서 저장하는 과정을 알아보자 1. 실행 : 스프링 애플리케이션 로딩 시점에 자동 프록시 생성기를 호출한다. 2. 모든 @Aspect 빈 조회 : 자동 프록시..

Spring/Spring 2022.01.20

빈 후처리기

이 포스팅은 인프런 김영한 님의 스프링 핵심 원리 고급 편을 보고 각색한 포스팅입니다. 자세한 내용은 강의를 확인해주세요 빈 후처리기란 무엇일까? 스프링이 빈 저장소에 등록할 목적으로 생성한 객체를 빈 저장소에 등록하기 직전에 조작하는 기능이다. 그림으로 간단하게 알아보자 1. A객체를 생성하고 2. A객체를 빈 후처리기에 전달한다. 3. A객체를 B객체로 바꿔치기하고 4. 스프링 빈 저장소에 B객체를 저장한다. 이해를 돕기위해 예제코드로 살펴보자 public class BasicTest { @Test void basicConfig() { ApplicationContext applicationContext = new AnnotationConfigApplicationContext(BasicConfig.cl..

Spring/Spring 2022.01.20

포인트컷, 어드바이스, 어드바이저

이 포스팅은 인프런 김영한 님의 스프링 핵심 원리 고급 편을 보고 각색한 포스팅입니다. 자세한 내용은 강의를 확인해주세요 포인트컷 : 어디에 부가 기능을 적용할지, 어디에 부가 기능을 적용하지 않을지 판단하는 필터링 로직이다. 주로 클래스와 메서드 이름으로 필터링한다. 이름 그대로 어떤 포인트에 기능을 적용할지 하지 않을지 잘라서 구분하는 것이다. 어드바이스 : 이전 포스팅에서 본 것 처럼 프록시가 호출하는 부가 기능이다. 단순하게 프록시 로직이라 생각하면 된다. 어드바이저 : 단순하게 하나의 포인트컷과 하나의 어드바이스를 가지고 있는 것이다. 쉽게 이야기해서 포인트컷1 + 어드바이스1이다. 정리하면 부가 기능 로직을 적용해야 하는데, 포인트컷으로 어디에 적용할지를 선택하고, 어드바이스로 어떤 로직을 적..

Spring/Spring 2022.01.19

프록시 팩토리

이 포스팅은 인프런 김영한 님의 스프링 핵심 원리 고급 편을 보고 각색한 포스팅입니다. 자세한 내용은 강의를 확인해주세요 앞서 마지막에 설명했던 동적 프록시를 사용할 때 문제점을 다시 확인해보자 문제점 1. 인터페이스가 있는 경우에는 JDK 동적 프록시를 적용하고, 그렇지 않은 경우에는 CGLIB를 적용하려면 어떻게 해야할까?2. 두 기술을 함께 사용할 때 부가기능을 제공하기 위해 JDK 동적 프록시가 제공하는 InvocationHandler와 CGLIB가 제공하는 MethodInterceptor를 각각 중복으로 만들어서 관리해야할까? Q: 인터페이스가 있는 경우에는 JDK 동적 프록시를 적용하고, 그렇지 않은 경우에는 CGLIB를 적용하려면 어떻게 해야할까? 스프링은 유사한 구체적인 기술들이 있을 때 ..

Spring/Spring 2022.01.19

동적 프록시

이 포스팅은 인프런 김영한 님의 스프링 핵심 원리 고급 편을 보고 각색한 포스팅입니다. 자세한 내용은 강의를 확인해주세요 지금까지 프록시를 적용하기 위해 적용 대상의 숫자 만큼 많은 프록시 클래스를 만들었다. 적용 대상이 100개면 프록시 클래스도 100개를 만들었다. 그런데 앞서 살펴본 것과 같이 프록시 클래스의 기본 코드와 흐름은 거의 같고, 프록시를 어떤 대상에 적용하는가 정도만 차이가 있었다. 쉽게 얘기해서 프록시의 로직은 같은데, 적용 대상만 차이가 있는 것이다. 이 문제를 해결하는 것이 바로 동적 프록시 기술이다. 동적 프록시 기술을 사용하면 개발자가 직접 프록시 클래스를 만들지 않아도 된다. 이름 그대로 프록시 객체를 동적으로 런타임에 개발자 대신 만들어준다. 그리고 동적 프록시에 원하는 실..

Spring/Spring 2022.01.18

디자인패턴 (프록시 패턴, 데코레이터 패턴)

이 포스팅은 인프런 김영한 님의 스프링 핵심 원리 고급 편을 보고 각색한 포스팅입니다. 자세한 내용은 강의를 확인해주세요 저번 포스팅에서 우리는 템플릿 메서드 패턴, 전략 패턴에 대해서 알아보았다. https://coding-review.tistory.com/93 디자인패턴 (템플릿 메서드 패턴, 전략 패턴) 이 포스팅은 인프런 김영한 님의 스프링 핵심 원리 고급 편을 보고 각색한 포스팅입니다. 자세한 내용은 강의를 확인해주세요 오늘 알아볼 패턴들을 보기 전에 간단한 예시를 먼저 소개하겠다. coding-review.tistory.com 앞서 배운 디자인 패턴들은 우리가 원했던 요구사항에 맞긴 하지만 코드를 직접 다 고쳐야 한다는 엄청난 부담감이 있다. 수백개면 수백개 수천개면 수천개의 코드를 일일히 다..

Spring/Spring 2022.01.17

디자인패턴 (템플릿 메서드 패턴, 전략 패턴)

이 포스팅은 인프런 김영한 님의 스프링 핵심 원리 고급 편을 보고 각색한 포스팅입니다. 자세한 내용은 강의를 확인해주세요 오늘 알아볼 패턴들을 보기 전에 간단한 예시를 먼저 소개하겠다. 비즈니스 로직을 실행하는데 있어서 어딘가에서 병목현상이 자꾸 벌어진다는 것을 확인했다. 어디서 병목현상이 발생하는지 알아보기 위해서 비즈니스 로직 앞뒤에 시간을 체크해 걸린 시간을 뽑아오라는 임무를 부여받았다. @Test void templateMethodV0() { logic1(); logic2(); } private void logic1() { long startTime = System.currentTimeMillis(); //비즈니스 로직 log.info("비즈니스 로직 1 실행"); //비즈니스 로직 종료 long..

Spring/Spring 2022.01.13