반응형
Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
Tags
- JPA 공부
- 자바공부
- 플러터 공부
- 스프링 공부
- 스프링
- 자료구조공부
- 스프링부트공부
- 코테공부
- JPA공부
- JPA예제
- 기술공부
- Kafka
- 플러터 개발
- nestjs
- nestjs공부
- Axon framework
- 프로그래머스
- 스프링부트
- DDD
- querydsl
- 알고리즘공부
- JPA
- JPA스터디
- 스프링공부
- nestjs스터디
- Flutter
- 카프카
- K8S
- 기술면접공부
- 코테준비
Archives
- Today
- Total
목록웹플럭스 실수 (1)
DevBoi
[WebFlux] Webflux 관련 머리속 정리
가끔 깜빡깜빡하다가 아차차..하던것들 Spring Mvc Spring Mvc는 Thread per Request이다. 쓰레드풀의 하나의 쓰레드를 리퀘스트에 쓰는 것이다. 쓰레드 하나가 모든일을 사용하고, 중간에 이 과정은 block된다. 시스템 부하가 크다면, 단순히 외부 network IO를 처리하는 것 자체에 서버 속도 처리 spec이 달라진다는 것이 문제이다. Webflux는 netty 기반이고, nginx와 동일하게, 이벤트 루프를 사용하여, 쓰레드를 사용한다. 단적인 예는 위의 그림과 같다. 하나의 쓰레드에서 외부 Api를 호출하고, 이 과정이 끝나면 다음 테스크에서는 이벤트 루프의 응답을 받은 쓰레드에서 이어서 처리를 한다. 높은 처리가 가능한 이유는, 각 쓰레드당 free한 쓰레드가 많아진다..
Develop/[WebFlux]
2023. 8. 7. 01:19