• Micrometer

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


  • @EnableWebMvc

    @EnableWebMvc @Enable로 시작하는 어노테이션은 자바 설정에서 편의를 제공하기 위해서 도입되었다. @Enable 어노테이션은 개발자를 대신해서 많은 설정을 대신해준다. 이번 글에서 살펴볼 어노테이션 @EnableWebMvc이다. @EnableWebMvc는 @Configuration 설정을 임포트하는 방식이다. 간단하게 코드로 살펴보자. @Retention(RetentionPolicy.RUNTIME) @Target(ElementType.TYPE) @Documented @Import(DelegatingWebMvcConfiguration.class) public @interface EnableWebMvc { } 코드를 보면 알겠지만 DelegatingWebMvcConfiguration를 임포트하고 있다. DelegatingWebMvcConfiguration는 @Configuration 설정이다. 그리고 DelegatingWebMvcConfiguration는...


  • Standby Task

    Standby Task Standby Task란 KafkaStreams는 State Store를 제공한다. 스트림 프로세싱 어플리케이션에서는 데이터를 저장하고 조회하기 위해서 State Store를 사용한다. 이는 Stateful Operation을 구현하기 위해 꼭 필요한 기능이다. KafkaStreams 내의 모든 Task들은 하나 이상의 State Store를 가질 수 있다. State Store에 데이터를 저장하거나 조회하기 위해 API를 통해 접근할 수 있다. State Store의...


  • Replying KafkaTemplate

    Replying KafkaTemplate ReplyingKafkaTemplate은 KafkaTemplate의 하위 클래스이다. ReplyingKafkaTemplate는 요청 / 응답 semantics을 제공한다. ReplyingKafkaTemplate는 sendAndReceive(ProducerRecord<K, V> record); 메소드를 추가로 가진다. RequestReplyFuture<K, V, R> sendAndReceive(ProducerRecord<K, V> record); 리턴값은 RequestReplyFuture이다. RequestReplyFuture는 ListenableFuture의 구현체이다. ListenableFuture는 비동기적으로 결과 혹은 예외가 채워진다. 또한 RequestReplyFuture는 sendFuture라는 속성을 가진다. sendFuture는 KafkaTemplate.send()의 결과이다. 따라서 sendFuture를 사용해서 send 연산의 결과를...


  • Avro, Compatibility

    Data Serialization and Evolution 네트워크를 통해 데이터를 전송하거나 파일에 저장할 때 데이터를 바이트로 인코딩해야 한다. 데이터 직렬화 영역은 오랜 역사가 있지만 지난 몇년 동안 상당히 발전했다. 초기에는 Java 직렬화와 같은 프로그래밍 언어 전용 직렬화를 사용했기 때문에 다른 언어에서 해당 데이터를 읽기 어려웠다. 그런 다음 JSON과 같이 언어에 구애받지 않는 형식으로...