/web22-LiBoo

컨퍼런스를 더 가까이, LiBoo 에서 라이브로 🚀

Primary LanguageTypeScript

thumbnail

컨퍼런스를 더 가까이, LiBoo 에서 라이브로 🚀

Notion   |   Figma   |   Wiki   |   BackLog


목차

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 프로젝트를 기획했습니다.

LiBoo가 만드는 변화와 목표

  • 누구나 쉽게 기술을 공유하고 배울 수 있는 열린 플랫폼
  • 팀원 간 소규모 공유부터 기업 컨퍼런스 협업까지 지원
  • 더 많은 사람들이 참여할 수 있는 기술 공유 기회 확대

📺 핵심 기능

feature-main feature-host feature-client feature-chat-client feature-chat-host


⚙️ 서비스 아키텍처

Streaming Data Architecture

🎥 호스트

단계 설명
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에 영구 저장됩니다.

🚀 CI/CD

구성 설명
배포 도구 프론트엔드백엔드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 으로 서버 인스턴스를 축소/확장할 수 있도록 관리

🛠️ 기술 스택

Part Stack
공통 Group 15
프론트엔드 Group 17
백엔드 Group 16

TEAM 정권지르기 👊

김준서 김영길 고민지 김지수 홍창현
BE BE FE FE FE
@i3kae @hoeeeeeh @gominzip @jsk3342 @spearStr