컨퍼런스를 더 가까이, LiBoo 에서 라이브로 🚀
1. 💻 데모 및 배포 링크
2. 🎯 기획 배경
3. 📺 핵심 기능
4. ⚙️ 서비스 아키텍처
4.1. 호스트
4.2. 클라이언트
4.3. CI/CD
5. 📝 핵심 기술 정리
5.1. 전체
5.2. 프론트엔드의 기술적 도전
5.3. 백엔드의 기술적 도전
6. 🛠️ 기술 스택
7. 👊 팀 소개
네이버 DAN, 토스 Slash, 카카오 If, 인프콘 등 다양한 컨퍼런스가 열리고 있지만, 참여는 여전히 쉽지 않습니다.
높은 경쟁률과 제한된 참가 인원 대신, 더 많은 사람들이 기회를 얻고 컨퍼런스 문화가 더욱 활발해지기를 바라는 마음으로 LiBoo 프로젝트를 기획했습니다.
- 누구나 쉽게 기술을 공유하고 배울 수 있는 열린 플랫폼
- 팀원 간 소규모 공유부터 기업 컨퍼런스 협업까지 지원
- 더 많은 사람들이 참여할 수 있는 기술 공유 기회 확대
단계 |
설명 |
1. 방송 시작 |
호스트는 OBS를 통해 방송을 시작합니다. |
2. 스트림 전송 |
OBS에서 생성된 RTMP 스트림을 RTMP 서버로 전송합니다. |
3. 스트림 변환 및 업로드 |
RTMP 서버는 스트림을 HLS 세그먼트(.ts 파일)와 index.m3u8 파일로 변환하고, 이를 Object Storage에 업로드합니다. |
4. 방송 정보 관리 |
API 서버와 방송 정보를 주고받아 클라이언트 대시보드에 방송을 노출시킵니다. |
5. 실시간 시청 |
클라이언트는 Object Storage에 직접 접근하여 HLS 세그먼트와 index.m3u8 파일을 통해 실시간 영상을 시청합니다. |
기능 |
설명 |
채팅 기능 |
호스트를 포함한 모든 클라이언트는 채팅 서버와 통신하여 실시간으로 채팅을 주고받을 수 있습니다. |
채팅 종류 |
채팅은 질문, 일반, 공지로 구분됩니다. |
질문 채팅 처리 |
질문 채팅은 1차적으로 Redis에 캐싱되며, 방송 종료 후 MySQL에 영구 저장됩니다. |
구성 |
설명 |
배포 도구 |
프론트엔드와 백엔드는 GitHub Actions, Docker, Docker Swarm을 활용하여 NCP에 배포됩니다. |
프로젝트를 진행하면서 겪은 다양한 경험과 학습 내용을 꾸준히 문서화하며 지식을 공유하고, 깊이 있는 기술적 도전을 이어나가고자 합니다.
- 처음 접하는 동영상 스트리밍 서비스의 동작 원리를 팀원들과 함께 이해하기
- 다양한 스트리밍 프로토콜(RTMP, WebRTC, HLS 등)을 검토한 결과, 실시간 단방향 스트리밍에 적합한 RTMP와 HLS 조합으로 결정
- 채팅 구현을 위해 실시간 양방향 통신 구현 방식에 대한 학습 진행
- 생산성을 고려해 broadcast, namespace, 자동 재연결이 구현되어 있는 socket.io 라이브러리를 사용하기로 결정
- socket.io를 통한 채팅 기능을 구현했으나, 컴포넌트 마운트 시 매번 새로운 소켓이 생성되는 이슈
- shared worker thread를 도입해 다중 탭에서도 하나의 소켓을 공유할 수 있도록 개선
- HLS 영상을 받아오는 비동기 데이터 페칭에서의 에러 핸들링
- 각각의 컴포넌트에서 로딩과 에러처리를 독립적으로 진행한 방식에서부터 AsyncBoundary를 활용하여 효율적인 비동기 데이터 페칭관리와 ErrorPage 라우팅까지 처리
- 호스트 페이지에 사용되는 많은 인풋을 리액트 훅 폼을 활용해 효율적으로 관리
- 훅 폼의 개념과 핵심 기능을 이해하고, controlled vs uncontrolled 컴포넌트, 폼 상태 관리 최적화 및 검증 로직 구현 방법을 탐구
- 서비스 별로 분리하여 확장이 쉽고, 유지 보수에 우수한 서버를 구축하고자 계획
- NestJS의 모듈화와 DI를 통해 각 도메인 간의 종속되지 않는 DDD 서비스 설계
- 각각의 서버가 intensive 한 부분을 고려해서 계획
- 서버를 분리해서 확장성을 고려
- 채팅 서버가 확장될 수 있음을 고려
- 채팅 서버 간, 데이터 공유를 위해 Redis 사용
- Redis 도 단일로 동작하지 않도록 redis-cluster 활용
- 서버를 도커 컨테이너로 올려서 docker-compose 로 관리
- docker swarm 으로 서버 인스턴스를 축소/확장할 수 있도록 관리