Spring 82

[Netty] Netty가 뭐에요? - 10: 정말 Netty는 빠를까? 2탄 - 대용량 데이터 처리 속도 비교(feat. Visual VM 활용하기)

지난 시간에는 실제로 Netty 가 일반 Blocking 으로 요청을 했을 때 보다 속도가 빠른지 성능 테스트를 해 보았다.(지난 내용이 궁금하면 여기 클릭!) 이번 시간에는 시나리오 2를 통해 성능을 좀 더 테스트해보려고 한다. 참고로 필자는 window 11 환경의 cmd 창에서 테스트를 진행했다. 0. 지난 내용을 복기해본다.1. 대용량 페이로드 테스트를 진행한다.2. 결과를 비교해서 어느것의 성능이 뛰어난지 확인한다.3. JVM 의 구조에 대해 이해한다. 4. VisualVM을 도입해서 JVM 현황을 파악한다.5. 결론 0. 지난 내용 복기지난 시간의 내용을 복기 + 정리하고 가려고 한다. Apache JMeter 를 다운로드 해서 세팅하는 법도 알아봤고 시나리오 1 대량 연결 유지 테스트 (..

[Netty] Netty가 뭐에요? - 10: 정말 Netty는 빠를까? 1탄 - 처리량과 지연시간 파악 (feat. Apache JMeter 활용하기)

이전 글에서는 어떻게 Java NIO는 비동기 프로그래밍을 구현했는지 알아보았다. (궁금하면 여기 클릭!) 이번 시간에는 다양한 예시를 통해서 성능 테스트를 해보려고 한다. 이를 Apache JMeter 를 사용하는 방법을 정리하면서 해가려고 한다. 목표0. Apachce JMeter 를 실행하는 법을 이해한다.1. 부하 테스트를 하기 위해서는 무엇을 고려해야 하는지 알아보고 시나리오를 작성한다.2. Spring boot 와 Netty 서버를 구축하고, 실제적으로 실행한 결과를 분석해본다. 0. Apache JMeter 다운로드 + 실행 필자는 Apache JMeter 공식 사이트에 들어가서 다음을 받았다. (다운로드 공식 사이트 여기!) 다운을 받으면 Github 사이트에서 어떻게 실행하는지 나와있..

[Netty] Netty가 뭐에요? - 부록2: NIO 는 어떻게 비동기를 구현했을까?

최근에 글을 계속 다시 정리하고 있는데, 문득 생각이 났다. 동일한 코드인데 어떻게 Java NIO는 비동기를 무엇을 통해서 구현했는지 궁금했다. 이에 대한 분석 및 이해를 하기 위한 글을 이번 섹션에서 정리한다. 목표 0. 동기와 비동기 그리고 블로킹과 논블로킹 차이점 재정리1. 비동기를 어떻게 구현하지?2. 직접 구현시의 문제점0. 동기 vs 비동기 & 블로킹 vs 논블로킹 차이점 재정리너무 자주 봤지만, 맨날 까먹는... 이 내용을 명확하게 다시 집고가자. 해당 내용은 Gemini에게 요청해서 내가 다듬도록 했다. 0.1) 동기와 비동기 (Synchronous vs Asynchronous)핵심 기준: "요청한 결과값을 누가, 언제 신경 쓰는가?" - 동기 (Synchronous)요청자(Caller)..

[Netty] Netty가 뭐에요? - 부록1: - Netty의 전체 구성도, Channel 분석 및 Bootstrap 활용법

이전 글에서는 Protocol Support 를 알아보았다. (이전 글 클릭) 현재 이전 글들을 보면서 다시 점검하고 있는데, Netty 시리즈 1~3탄 까지는 어느정도 써먹을 만 한데 그 이후는 영... 크게 머리에 쏙쏙 박히지 않고 글을 작성한 본인조차 다시 보려니 뭘 말하고 싶은건지 명확히 와닿지 않는 부분이 많았다. 이러한 문제들은 차차 정리할 예정이지만 읽다보니 그런데 문득 생각이 들었다. Netty에서는 다양한 Channel과 개발을 편리하게 해주는 기능을 제공해주고 있는데 Channel의 구현체들의 존재 이유와 어느 상황에서 어느 Channel이 좋은건지 파악하고, Bootstrap의 명확한 사용방법을 큰 그림을 그려가면서 알아가려고 한다. 사실 Channel 에 대해서는 해당 글..

[Netty] Netty가 뭐에요? - 9탄 : 공식 문서 - Protocol Support 탐방 (zbli/gzip Compression, Large File Transfer, RSTP, Legacy Text & Binary Protocols with Unit Testability)

해피뉴이어! 올해 새해가 밝았고, 2026년의 첫번째 글은... Netty가 차지하게 되었다 와.. 쩐다... 지난 시간에는 Protocol Support 섹션의 HTTP & WebSocket / SSL & StartTSL / Google Protobuf에 대해 알아보았다. (궁금하면 여기 클릭) 이번 시간에는 Protocol Support 섹션의 나머지를 알아보려고 한다. zbli/gzip Compression, Large File Transfer, RSTP, Legacy Text & Binary Protocols with Unit Testability가 이에 해당한다. 그럼 다시 한 번 가... 보자고! 1. zlib/gzip Compression 해당 섹션의 Package Summary를 보면..

[Netty] Netty가 뭐에요? - 8탄 : 공식 문서 - Protocol Support 탐방 (HTTP & WebSocket / SSL & StartTSL / Google Protobuf)

지난 시간에는 Netty의 구조 중 Core와 Transport Services에 대해 알아보았다. (지난 내용은 여기!) 이번에는... 가장 잘게 쪼개져 있는 섹션인 Protocol Support를 보려고 한다. 이전과 동일하게 각각 항목에서 이것들이 도대체 무슨 말인지... 이해를 해보려고 한다. 그러면 시작 전에... 다시 구조를 보도록 하자. 0. Protocol Support사실 너무 기본적이고... 지겹지만 그래도 다시 한 번 체크하자. Protocol은 무엇인가? 규약이다. 사람들끼리 대화를 한다고 하면, 어느 언어로 할지 정해야 한다. 예를 들어 한국사람들은 보통 한국어로 말을 하지만 영국인은 영어를 할 것이다. 이와 마찬가지로 컴퓨터나 장치들은 대화를 하는게 아니라 데이터를 주고받는데,..

[Spring Framework] 웹소켓 공식문서 읽기 1 - WebSocket API, SocketJS Fallback 그리고 STOMP Overview & Benefits

사실 필자는 학창시절에 다 외우면 공부를 잘하는 것이라고 생각했다. 하지만, 이해가 수반되어야 그 어떤것이라도 외울 수 있는 것이라고 최근에서야 깨달았고, (오 나의 늦은 20대의 고백~) Netty공식문서를 읽어보니 Web Socket을 지원한다길래 이게 Spring Framework에서 지원하는 Web Socket과 무엇이 다른지 알기 위해서 글을 다시 정리한다. 그냥 공식문서를 읽어보는건데, 가장 흔한 채팅방을 기준으로 생각해보겠지만 이를 정말 많은 사람이 접근할 시 어떻게 설계를 해야 하는지 공부하고 정리하려고 한다. (귀찮음을 극복할 수 있다면 말이다 하하) 해당 글은 Spring > WebSockets 공식문서를 참고해서, 이해가 안되는 부분에 살을 붙여서 정리한 것이니 해당 글을 봐주면 ..

[Netty] Netty가 뭐에요? - 7탄 : 공식 문서 - Core 정리 및 Tansport Services 탐방

지난 시간에는 Netty에서 제공하는 Echo 예제를 보았다. (지난 글 여기 클릭!) 사실 글 길이는 별거 안되어 보이지만 변명(?)을 하자면 이걸 어떻게 구성을 하는게 내가 이해가 더 잘될지 고민했기 때문이다. 또 단순히 코드를 탐방하는 경우, 흐름을 주석으로 정리한 것을 접어버리다 보니 상대적으로 양은 적어보였다. 현재는 Netty의 모든 것을 한 번에 뜯어볼 수 는 없으니, 현재 차근차근 뜯어보고 있는 상황이다. 그러면 다시 ... 핵심 구조를 다시 보고 가자. 이미 우리는 Zero-Copy-Capable Rich Byte Buffer에 대해서 공부했다. (Rich Byte Buffer 내용은 여기!) 이번에는.. Universal Communication API와 Extensible Event ..

[Netty] Netty가 뭐에요? - 6탄 : 공식 문서 - Echo 테스트 학습

지난 시간에는 Netty 학습 5탄에서 ByteBuf에 대해서 상세히 알아보았다.(이전 내용은 여기 클릭!) 이번에는 Netty 학습 4탄에서 미처 이어가지 못했던 예시 학습을 이어서 하려고 한다.(4탄 내용은 여기 클릭!)1. Composite Pattern과 Netty우선 예시를 더 보기 전에 필자는 해당 클래스들을 알게 되었다. EventExecutor 가 EventExecutorGroup을 상속하고EventExecutorGroup은 내부에 Iterator에 EventExecutor를 담고 있는 구조다. 무언가 Composite Pattern과 익숙하다. Composite Pattern 개별 객체와 객체 그룹을 똑같은 방식으로 다루는 디자인 패턴이다. 공통된 operation을 선언하고 Compo..

[Netty] Netty가 뭐에요? - 5탄 : Netty Architecture - ByteBuf Summary 읽기

지난 시간에는 Spring MVC, Spring Web Flux에 대해 간단 정리했고 Netty의 차이점이 뭔지 알아보았으며, Netty가 돌아가는 큰 그림을 그려보고 가장 쉬운 예시 코드를 통해서 학습을 했다.(지난 내용 여기 클릭!) 이번에는 4탄에서 논의하느라 놓친 Netty 의 Architecture에 대해 알아보고자 한다. 지난 예시에서 봤던 NioEventLoopGroup, ServerBootStrap, ChanelInitializer 들이나 예시들은... 6탄에서부터 확인해면 될 듯 하다 ㅠㅠ.. 해당 글은 Javadoc 에서 소개하는 글을 io.netty.buffer 패키지를 중심으로 읽어보고, 핵심 클래스 구조들에 대해서 좀 더 알아보려고 한다. 참고로 3.x 버전까지는 뭔가 별도로 웹에..