Mono

    [Java] Java 8 Streams - Reactor map() 과 flatMap() 차이

    map / flatMap 은 언제 사용해야 하나 map / flatmap 둘다 스트림의 중간에 값을 변환해주는 역할을 한다. map은 1 : 1로 반환을 보증하고 flatMap은 1 : N을 변환할 수 있다. Mono와 달리 Flux 는 비동기로 병렬 동작하는 publisher 를 사용하는 경우 성능상 이점이 많기 때문에 되도록 flatMap 을 사용하는게 좋다. reactive한 개발을 하면 사용하는 모든 method의 반환은 publisher 형태가 된다. 이렇게 반환된 결과값을 사용해야 하는 경우에는 map 보다 flatMap 을 사용할 때 자연스럽게 이어진다. 이러한 경우 때문에 Mono -> Mono 의 경우에도 flatMap을 사용하게 된다. 동기 처리 부분은 map 비동기 처리부분은 flat..

    Spring WebFlux

    Spring WebFlux

    WebFlux 란 WebFlux 는 Spring 5에서 새롭게 추가된 모듈이다. 클라이언트, 서버에서 reactive 스타일의 어플리케이션 개발을 도와주는 모듈이며 Non-blocking 에 reactive streams 의 BackPressure을 지원하며 Netty, Servlet3.1+ 컨테이너와 같은 서버에서 실행된다. 위의 그림은 각각의 기능들과 공통점에 대해 나와있다. 위는 전반적인 WebFlux의 구조이다. WebFlux 를 사용하기 전에 WebFlux 가 왜 생겨났는지 궁금했다. WebFlux 가 생긴 이유 적은 수의 스레드와 최소한의 하드웨어 자원으로 동시성을 처리하고 리소스를 확장하기 위해서 만들어졌다. 이는 새로운 공통 API 가 생긴 이유가 됐으며, tomcat 이 아닌 netty와..