Socket.io(3)
-
5. [최적화2] Nginx 및 WebSocket 서버 설정 최적화
1. 최적화가 필요한 이유기본 설정의 한계: Nginx나 WebSocket 서버는 기본적으로 낮은 연결 제한과 짧은 타임아웃 값을 가짐동시 연결 수가 많아질 경우 병목 현상 초래 가능테스트 결과 분석WebSocket 에러 증가: 연결 타임아웃 또는 불완전한 메시지 전송이 원인일 수 있음응답 시간 편차: 높은 P95/P99 응답 시간은 서버 자원의 과부하를 나타냄2. 최적화 조치(1) Nginx 연결 제한 및 이벤트 핸들링 최적화Nginx가 동시에 처리할 수 있는 연결 수와 CPU 코어 활용도 설정# Nginx 설정 파일 (예: /etc/nginx/nginx.conf)worker_processes auto; # 사용 가능한 CPU 코어 수만큼 워커 생성 (t2.micro는 1개)worke..
2025.01.24 -
2. Artillery를 활용한 Socket.IO 기반 채팅 서비스 부하 테스트: Local vs EC2 환경 성능 비교 및 분석
Intro실시간 시스템, 특히 채팅 서비스에서 부하 테스트는 매우 중요 Socket.IO는 실시간 통신을 쉽게 구현할 수 있는 라이브러리로, WebSocket을 기반으로 동작하며 자동 폴백 메커니즘을 제공이 글에서는 Artillery를 사용해 Socket.IO 기반 채팅 서비스를 테스트하는 초기 단계 테스트 시나리오를 다룬다. 또한, 로컬 환경과 EC2 환경에서의 테스트 결과를 비교하고, 이러한 테스트가 시스템에 미치는 영향 분석채팅 서비스 개요1. 주요 기능유저 인증: 이메일과 비밀번호를 사용한 로그인친구 관리: 친구 목록 가져오기 및 친구 선택실시간 채팅: 채팅방 생성 및 메시지 전송2. 시스템 아키텍처Backend: Node.js 서버(NestJS)Database: PostgreSQL(+ TypeO..
2025.01.14 -
1. 부하테스트를 위한 테스트 도구 도입
Artillery란?성능 테스트와 부하 테스트를 위한 간단하고 강력한 도구HTTP, WebSocket, GraphQL 등 다양한 프로토콜을 지원하는 부하 테스트 도구AWS free tier 만으로 어느정도 트래픽까지 감당 가능할지 알아보기 위하여프로젝트 배경NestJS와 Socket.IO를 사용해 실시간 채팅 서비스 구축높은 동시 연결을 처리하고 안정적인 성능을 제공하기 위해 성능 테스트가 필수목표Artillery를 사용해 성능 테스트를 설정, 실행, 분석하는 과정을 공유성능 병목을 해결하고 효율적인 실시간 시스템 설계 구축부하테스트 필요성성능 검증: 웹사이트나 API가 높은 트래픽에서도 안정적으로 작동하는지 확인취약점 발견: 높은 요청으로 인해 발생할 수 있는 병목현상과 오류를 미리 확인WebSocke..
2025.01.14