inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

스프링 MVC 1편 - 백엔드 웹 개발 핵심 기술

메세지 전송 지연의 병목 지점 파악 방법

158

푸딩

작성한 질문수 3

0

안녕하세요 김영한 개발자님
강의 감사합니다!
강의 내용과 직접적인 연관은 없을 수 있지만 질문이 있습니다...

혹시 Spring 서버에서 또 다른 SpringMVC 서버 또는 Spring Webflux 서버로 요청을 보내고
또 그 서버에서 Client로 요청을 보내는 구조에서 메세지 전송 지연이 발생했을 때
어느 부분이 병목인지 파악하고자 한다면 어떤 방법을 사용하면 좋을까요....?

제가 아직 지식이 짧아서 더 경험이 많으신 개발자분께서는 이런 상황일 때 어떻게 하실지 궁금합니다... ㅠ_ㅠ
Rest 요청이 들어온 시점에 해당 시각을 로그로 남기고, 응답을 보내는 시점에 해당 시각을 로그로 남겨서 판단하는 방법 외에 더 좋은 방법이 있을까요......?

spring mvc

답변 2

0

김영한

안녕하세요. 푸딩님

인프런 AI 인턴이 잘 답변해주었는데요.

A 서버 -> B 서버 -> C 서버로 서로 연계되어 있는 상태이군요.

이 상황에 어디에서 시간이 오래 걸렸는지 찾아야 하는 상황이구요.

이런 경우에는 AI 인턴이 설명한 1번 방법을 찾아보시면 도움이 됩니다.

추가로 네이버 핀포인트도 해당 부분을 자동으로 해결해주니 참고해보시면 도움이 되실거에요.

감사합니다.

0

인프런 AI 인턴

안녕하세요, 인프런 AI 인턴입니다. 푸딩님!

메시지 전송 지연의 병목 현상을 파악하는 것은 성능 최적화와 관련하여 매우 중요한 주제입니다. Spring 서버 간의 통신에서 병목 지점을 찾기 위한 방법 중 몇 가지를 소개해드리겠습니다.

  1. 로그 및 트레이싱: 말씀하신 것처럼 로그를 남기는 것은 기본적인 방법입니다. 이를 더 보강하기 위해 Spring Cloud Sleuth를 사용하여 요청의 트레이싱 데이터를 생성하고, Zipkin을 활용하여 시각화할 수 있습니다. 이렇게 하면 요청의 흐름을 추적하여 어디에서 시간이 많이 소요되는지 확인할 수 있습니다.

  2. 모니터링 툴 활용: Prometheus와 Grafana 또는 ELK Stack(Elasticsearch, Logstash, Kibana)을 통해 시스템 성능을 모니터링하고 분석할 수 있습니다. 이러한 도구들은 서버의 각종 메트릭(예: CPU 사용량, 메모리 사용량, 네트워크 대역폭 등)을 수집 및 시각화하여 병목 현상을 진단하는 데 도움을 줍니다.

  3. 프로파일링 도구 사용: Spring 애플리케이션에서는 JVM 프로파일링 도구인 VisualVM이나 YourKit, JProfiler 등을 사용하여 애플리케이션의 CPU 및 메모리 사용을 분석하고, 코드 레벨에서의 병목 지점을 파악할 수 있습니다.

  4. 비동기 처리 고려: Spring MVC 대신 WebFlux를 사용하여 비동기적으로 처리하고, Reactor나 CompletableFuture를 활용하여 병렬 처리를 고려할 수 있습니다. 이는 특히 I/O가 많은 작업에서는 성능을 크게 향상시킬 수 있습니다.

위의 방법들을 통해 병목 지점을 파악하고, 적절히 최적화해 나가시길 바랍니다.

저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다. 현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏 추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.

servlet과 container에 대한 질문입니다

0

25

1

api를 어느 컨트롤러에 작성해야하는지는 어떤 기준으로 해야하나요?

0

64

1

jsp 의존성 수정 요청

0

79

2

요즘 웹 서버가 주로 사용되는 이유는 SPA 구조 때문일까요 ?

0

143

1

save() 메서드 문의

0

67

1

절대 경로로 templates/basic 하위 파일 열면 css 적용 안되는 현상

0

101

1

request-body-json

0

83

2

MVC 패턴의 적용 단위

0

97

1

RequestMapping을 이용한 핸들러, 어댑터

0

119

2

save 후 결과화면

0

89

2

jsp를 이용한 view

0

97

1

application.properties에 debug 추가해도 결과가 똑같습니다.

0

178

1

수업 코드 제공 관련 문의

0

97

2

RequestMappingHandlerAdapter의 Controller 호출 과정

0

100

3

파일 오픈 시

0

70

1

스프링 배치 관련

0

78

1

@RequestParam의 defaultValue가 blank 값도 처리하는 지 여부

0

112

1

postman으로 /request-body-json-v1 호출시 500 error

0

96

1

프론트엔드와 백엔드의 mvc, rest api에 대한 질문

0

79

1

모델의 역할과 계층 분리에 대한 이해 차이 + 추가질문

0

111

1

console log 출력 관련 질문입니다.

0

75

1

애플리케이션이 실행 되지 않습니다 ㅠㅠㅠ

0

139

1

html 변경하는 부분 적용 문제

0

103

1

한글 깨짐

0

76

2