• ProductionExceptionHandler

    ProductionExceptionHandler ProductionExceptionHandler를 사용하면 브로커에 메시지를 보낼때 예외가 발생하는 경우 이를 처리할 수 있다. 기본 구현체는 DefaultProductionExceptionHandler로 항상 FAIL을 리턴한다. FAIL을 리턴하는 경우에는 Stream이 셧다운된다. ProductionExceptionHandler의 handle 메소드에서는 FAIL 또는 CONTINUE를 리턴할 수 있다. 보통은 어떤 Exception이 발생했느냐에 따라서 리턴되는 값이 결정된다. FAIL을 리턴하는 경우 Stream은 셧다운된다. 반면에 CONTINUE를 리턴하는 경우에는...


  • Reactive Streams

    Reactive Streams Reactive Reactive는 아래 4가지 특징을 가지고 있어야 한다. Reactive manifesto Responsive (응답성) : 리액티브 시스템은 가능한 모든 요청에 대해 적시에 응답할 수 있어야한다. 또한 발생한 문제에 대해 빠르고 효율적으로 대응할 수 있어야한다. 시스템은 언제나 응답 가능한 상태로 존재해야한다는 개념이다. Elastic (탄력셩) : 시스템은 변화하는 부하에 의해 자원의 변경이...


  • Java Future

    Future, CompletableFuture, ListenableFuture Future Future는 비동기 처리 결과를 표현하기 위해서 사용된다. 비동기 처리가 완료되었는지 확인하고, 처리 완료를 기다리고, 처리 결과를 리턴하는 메소드를 제공한다. 비동기 결과는 처리가 완료되면 get 메소드를 사용해서 얻을 수 있다. get 메소드는 비동기 처리가 완료될 때까지 blocking 된다. 비동기 작업을 취소하려면 cancel 메소드를 사용하면 된다. 비동기 작업이...


  • Testing your Auto-configuration

    Testing your Auto-configuration ApplicationContextRunner는 Spring Boot 2.0에서 추가된 내용이다. 그 이전 버전에서는 ApplicationContextRunner를 사용할 수 없다. ApplicationContextRunner Spring boot의 auto-configure는 여러 요인에 영향을 받는다. 사용자 설정 (@Bean 정의 그리고 Environment 설정), 특정 라이브러리의 존재 여부 등이 auto-configure에 영향을 준다. ApplicationContextRunner는 이러한 auto-configure를 테스트하기 위해서 사용한다. ApplicationContextRunner는 일반적으로 테스트 클래스의 필드로...


  • Micrometer

    Micrometer Micrometer란? 마이크로미터는 모니터링 시스템을 위한 측정 클라이언트에 대한 파사드를 제공한다. (SLF4J와 유사하다) 마이크로미터에 의해서 기록된 어플리케이션 메트릭 정보는 주로 모니터링 용도 또는 알람의 용도로 사용된다. 메트릭 정보를 수집하기 위해서 약간의 코드만 추가하면 되도록 설계되어있다. 또한 메트릭 정보의 이식성을 극대화하였다. 마이크로미터는 다음과 같은 모니터링 시스템을 지원한다 : Atlas, Datadog, Graphite,...