메세지 전송 지연의 병목 지점 파악 방법
158
작성한 질문수 3
안녕하세요 김영한 개발자님
강의 감사합니다!
강의 내용과 직접적인 연관은 없을 수 있지만 질문이 있습니다...
혹시 Spring 서버에서 또 다른 SpringMVC 서버 또는 Spring Webflux 서버로 요청을 보내고
또 그 서버에서 Client로 요청을 보내는 구조에서 메세지 전송 지연이 발생했을 때
어느 부분이 병목인지 파악하고자 한다면 어떤 방법을 사용하면 좋을까요....?
제가 아직 지식이 짧아서 더 경험이 많으신 개발자분께서는 이런 상황일 때 어떻게 하실지 궁금합니다... ㅠ_ㅠ
Rest 요청이 들어온 시점에 해당 시각을 로그로 남기고, 응답을 보내는 시점에 해당 시각을 로그로 남겨서 판단하는 방법 외에 더 좋은 방법이 있을까요......?
답변 2
0
안녕하세요. 푸딩님
인프런 AI 인턴이 잘 답변해주었는데요.
A 서버 -> B 서버 -> C 서버로 서로 연계되어 있는 상태이군요.
이 상황에 어디에서 시간이 오래 걸렸는지 찾아야 하는 상황이구요.
이런 경우에는 AI 인턴이 설명한 1번 방법을 찾아보시면 도움이 됩니다.
추가로 네이버 핀포인트도 해당 부분을 자동으로 해결해주니 참고해보시면 도움이 되실거에요.
감사합니다.
0
안녕하세요, 인프런 AI 인턴입니다. 푸딩님!
메시지 전송 지연의 병목 현상을 파악하는 것은 성능 최적화와 관련하여 매우 중요한 주제입니다. Spring 서버 간의 통신에서 병목 지점을 찾기 위한 방법 중 몇 가지를 소개해드리겠습니다.
로그 및 트레이싱: 말씀하신 것처럼 로그를 남기는 것은 기본적인 방법입니다. 이를 더 보강하기 위해 Spring Cloud Sleuth를 사용하여 요청의 트레이싱 데이터를 생성하고, Zipkin을 활용하여 시각화할 수 있습니다. 이렇게 하면 요청의 흐름을 추적하여 어디에서 시간이 많이 소요되는지 확인할 수 있습니다.
모니터링 툴 활용: Prometheus와 Grafana 또는 ELK Stack(Elasticsearch, Logstash, Kibana)을 통해 시스템 성능을 모니터링하고 분석할 수 있습니다. 이러한 도구들은 서버의 각종 메트릭(예: CPU 사용량, 메모리 사용량, 네트워크 대역폭 등)을 수집 및 시각화하여 병목 현상을 진단하는 데 도움을 줍니다.
프로파일링 도구 사용: Spring 애플리케이션에서는 JVM 프로파일링 도구인 VisualVM이나 YourKit, JProfiler 등을 사용하여 애플리케이션의 CPU 및 메모리 사용을 분석하고, 코드 레벨에서의 병목 지점을 파악할 수 있습니다.
비동기 처리 고려: 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





