전체 글

전체 글

    [Spring] 빈 후처리기<img src=">

    [Spring] 빈 후처리기

    이전에 작성했던 프록시 팩토리의 문제점을 해결하기 위해서 빈 후처리기를 사용한다고 했다. 프록시 팩토리 내용에 대해 알고싶으면 아래 링크를 참고하면 된다. https://bsssss.tistory.com/1482  빈 후처리기란 일반적으로 @Bean 이나 @Component 를 사용하면 스프링은 대상 객체를 생성하고스프링 컨테이너 내부의 빈 저장소에 등록한다. 빈 후처리기는 객체를 조작할 수도 있고, 다른 객체로 바꿔치기 하는 것도 가능하다.  빈 후처리기 - 스프링 빈 등록 과정생성 : 스프링 빈 대상이 되는 객체를 생성(@Bean, 컴포넌트 스캔 포함)전달 : 생성된 객체를 빈 저장소에 등록하기 직전에 빈 후처리기에 전달후 처리 작업 : 빈 후처리기는 전달된 스프링 빈 객체를 조작하거나 다른 객체로 ..

    [Spring] 프록시 팩토리<img src=">

    [Spring] 프록시 팩토리

    프록시 팩토리란 프록시 패턴은 인터페이스가 있으면 JDK 동적 프록시를 사용하고 구체 클래스만 있다면 CGLIB를 사용하며 이 설정을 변경할 수도 있다.  스프링에서 이 두개를 사용할 때 InvocationHandelr, MethodInterceptor 를 따로 만들지 않고 Advice를 호출해서 두개다 호출해서 사용한다. 스프링에서 Pointcut 이라는 개념으로  프록시 팩토리를 사용해서 Advice만 호출하면 나머지는 스프링에서 호출해서 사용할 수 있게해 이 문제를 일관성 있게 해결한다.   프록시 팩토리 관련 자주 사용하는 용어 정리포인트컷(pointcut)어디에 부가 기능을 적용할지 판단하는 필터링 로직 주로 클래스와 메서드 이름으로 필터링함어떤 point에 기능을 적용할지 안할지 잘라서(cut..

    [Java] 동적 프록시 (JDK 동적 프록시, CGLIB)

    [Java] 동적 프록시 (JDK 동적 프록시, CGLIB)

    JDK 동적 프록시 인터페이스 기반으로 프록시를 동적으로 만들어 사용하기 때문에 인터페이스가 필수이다. 자바에서는 리플렉션을 사용해 proxy 클래스를 제공해주고 있다.  리플렉션(Refliction)이란 구체적인 클래스 타입을 알지 못해도 그 클래스의 메서드, 타입, 변수들에 접근할 수 있도록 해주는 자바 API 이다. 사용 시기는 동적으로 클래스를 사용해야할 때 사용하는데 작성 시점에는 어떤 클래스를 사용할지 모르지만 런타임 시점에 가져와 실행해야하는 경우에 필요하다. 단점은 메서드에 값이 잘못 입력 되어도 컴파일 오류가 발생하지 않고 해당 코드를 직접 실행하는 시점에 런타임 오류가 발생해서 그때 오류를 알 수 있다. 이러한 이유로 리플렉션을 잘 사용하지 않고, 만약 사용하게 된다면 공통 처리가 필요..

    CKA 자격증 취득을 위한 학습 방법 및 시험 팁 및 후기

    CKA 자격증 취득을 위한 학습 방법 및 시험 팁 및 후기

    자격증 취득 이유cka를 통해 얻고자 하는 것은 쿠버네티스에 대해 아는 것과, 관리자로써 어느정도 필요한 능력과 검증할 자료를 가지고자 하기 위해서 이다. 인프라 DevOps 에 관심이 있기도 해서 공부할 겸 자격증을 취득하고자 했다.   학습방법1cka 강의를 검색하면 가장 많이 추천하는 Udemy 강의 를 신청했다. 강좌 후반부에 있는 Mock Exam은 최소 2번 이상 하는 것을 추천한다. udemy 에서 연습할 수 있는 실습환경인 kubekloud 도 제공해준다.     2따배쿠 강의 유튜브 구독 or 패스트캠퍼스 강의 유데미에서 이해안가는 내용을 따배쿠에서 들으면 도움이 된다. 즐겨찾기에 대해서도 공유해준다. 근데 이제는 시험에서 즐겨찾기 기능을 사용할 수가 없다. 즐겨찾기 기능 없이 문서 내에..

    [Java] 프록시 패턴, 데코레이터 패턴

    [Java] 프록시 패턴, 데코레이터 패턴

    프록시란 프록시의 뜻은 대리자, 대변인으로 누군가 일일 대신 시키는 것을 의미하는데 프로그램에서 사용 되는 뜻도 클라이언트가 객체를 직접 사용하는 것이 아니라 중간에 프록시를 거쳐 사용하는 것이다. 프록시 패턴이란 객체를 대리자가 대신 처리함으로 써 로직의 흐름을 제어하는 패턴이다. 어떤 객체를 사용하고자 할때, 객체를 직접적으로 참조하는 것이 아닌 해당 객체를 대항하는 객체를 통해 대상 객체에 접근하는 방식을 사용하면 해당 객체가 메모리에 존재하지 않아도 기본적인 정보를 참조하거나 설정할 수 있고, 실제 객체의 기능이 필요한 시점까지 객체의 생성을 미룰 수 있다. 서버와 프록시의 같은 인터페이스 사용 클라이언트는 서버 인터페이스에만 의존한다. 서버와 프록시가 같은 인터페이스를 사용해서 DI를 사용해서 ..

    [Java] 템플릿 메서드 패턴, 전략 패턴, 템플릿 콜백 패턴

    [Java] 템플릿 메서드 패턴, 전략 패턴, 템플릿 콜백 패턴

    템플릿 메서드 패턴 템플릿 메서드 패턴이란, 여러 클래스에서 공통으로 사용하는 메서드를 템플릿화하여 상위클래스에서 정의하고 하위 클래스마다 세부 동작을 다르게 구현하는 패턴이다. 템플릿 메소드 패턴은 상속이라는 기술을 극대화하여, 알고리즘의 뼈대를 맞추는 것에 초점을 둔다. 변하지 않는 템플릿(기능)은 상위 클래스에만 만들어두고 자주 변경되며 확장할 템플릿(기능)은 하위 클래스에서만 만든다. 이렇게 하 면 자식 클래스가 알고리즘의 전체 구조를 변경하지 않고, 특정 부분만 재정의할 수 있는데 하위 클래스를 사용해 상속과 오버라이딩을 통 한 다형성으로 문제를 해결하는 것이다. 템플릿 메서드 패턴은 클래스를 계속 만들어야 하는 단점이 있는데 익명 내무 클래스를 사용하면 이러한 단점을 보완할 수 있다. 익명 내..

    [Java] 스레드 로컬 - Thread Local

    스레드 로컬이란 여러개의 스레드가 존재할 때, 해당 스레드만 접근할 수 있는 특별한 저장소를 말한다. 스레드 로컬 클래스는 한 스레드에 의해 읽고 쓰여지는 변수를 생성한다. 각 스레드마다 별도의 내부 저장소가 제공된다. 스레드 로컬을 사용하는 이유 , 동시성 문제 서로 다른 두 스레드가 하나의 변수에 접근해 동시에 값을 변경한다면 이 변수는 공유 자원으로 동시성 문제가 발생할 수 있다. 동시성 문제는 트래픽이 적은 상황에서는 괜찮은데 트래픽이 많아질수록 자주 발생한다. 또한 스프링 빈처럼 싱글톤 객체의 필드를 변경하며 사용할 때도 동시성 문제에 대해 조심해야 한다. 이러한 문제를 해결하기 위해 스레드 로컬을 사용한다. 스레드 로컬 사용 시 주의사항 스레드 로컬을 모두 사용하고나면 remove 메서드를 호..

    [Gradle] Gradlew 빌드 시 gradle 다운로드 속도가 느릴 때

    이미지 빌드 중 ./gradlew 실행을 위해 gradle 다운로드하는데 시간이 너무 오래걸리는 문제가 있었다. 빠를때도 있고 느릴때도 있었는데 계속 기다릴 수 없기에... 해결해보는걸로 하자. 찾아보니 종종 배포파일 다운로드가 느리다는 것 같았다. 해결 방법으로는 다운로드 받는 gradle 주소를 변경해서 진행하면 된다. 파일 위치는 gradle/wrapper/gradle-wrapper.properties 에 있고 distributionUrl 에 있는 주소를 변경해주면 된다. Downloading https://services.gradle.org/distributions/gradle-[버전]-bin.zip Downloading https://downloads.gradle.org/distributions..

    [Spring] Thread Pool - pool size설정

    Thread Pool Thread Pool 은 여러 개의 쓰레드를 유지하고 관리하기 위해 사용된다. Thread Pool 의 사이즈 쓰레드를 불필요하게 많이 만들게 되면 메모리의 낭비가 심해지고 너무 적은 수의 쓰레드를 만들게 되면 효율성이 떨어진다. 쓰레드의 개수를 고정 시키는 것보다 서비스가 실행되는 CPU의 코어 개수에 따라 유동적으로 생성할 수 있도록 해주는 것이 좋다. 많이 생성하는 것이 아니라 어떤 작업을 처리하느냐에 따라 기준이 바뀔 수 있다. CPU 처리가 많은 경우 - CPU 코어가 N개인 경우 N+1만큼의 쓰레드를 생성해주면 최적에 가까운 성능을 낼 수 있다고도 한다. I/O 작업이 많은 경우 - N*2 만큼의 쓰레드를 생성해준다.

    [Querydsl] Resolved [com.querydsl.core.types.ExpressionException ~ ]

    selet 문에 내가 원하는 값으로 리턴하기 위해 Querydsl 에서 Projections.fileds를 사용하는데 다음과 같은 에러가 발생했었다. @Override public List getMasterIdList(Long memberId) { return jpaQueryFactory.select( Projections.fields(AnswerDTO.class, answer.answerId.as("answerId"), answer.answerId.count().coalesce(0L).as("answerCount")) ) .from(answer) .where(answer.mberId.eq(memberId)) .fetch(); } Projections의 경우 생성자 기반이 아닌 필드 기반으로 가져올 때 ..