Skip to content
Kang Chaeryeon edited this page Nov 22, 2024 · 51 revisions

2FAD2B6A-A248-4463-AFDE-0C48BFFBA3B1

 

🎵 inear 프로젝트 개요

iNear는 팬들끼리 좋아하는 아티스트의 신규 앨범을 함께 공감하는 공간입니다 사용자는 앨범 발매 당일날 좋아하는 아티스트의 노래를 실시간으로 듣고, 같은 팬들과 함께 서로의 감상평을 실시간 채팅으로 함께 공유하며 즐거운 추억을 보낼 수 있습니다.

🔔 유저 페르소나

iNear는 기존의 소통의 창구가 적었던 장르의 아티스트를 팔로우하고 있던 팬들을 위한 소통의 장입니다. 같은 취향을 공유하는 사람들과 함께 좋아하는 아티스트의 앨범 발매 당일날을 더 풍성하게 만들어보세요.

🚀 핵심 기능

실시간 앨범 스트리밍

inear는 아티스트의 신규 앨범을 실시간으로 청취할 수 있습니다

  • 앨범 발매 라이브 세션이 진행되기 1시간 전에 홈페이지에 배너가 등록이 됩니다
  • 유저는 미리 들어와서 가수의 이전 앨범을 함께 들을 수 있습니다
  • 앨범 발매 시간에 맞추어 세션 안에서 라이브로 신곡을 들을 수 있습니다

실시간 채팅방에서 소통

inear는 앨범 청취를 하면서 다른 사용자들과 소통할 수 있습니다

  • 같은 팬들끼리 서로 실시간 채팅으로 다같이 소통할 수 있습니다
  • 채팅방에서 본인이 직접 이미지 기반의 커스텀 이모지를 등록하고 사용할 수 있습니다
  • 앨범 스트리밍을 하면서 가장 좋은 노래에 유저들이 실시간으로 투표를 진행할 수 있습니다

✨ 부가 기능

커스텀 이모지 사용

  • 자신이 가진 파일을 이모지로 등록하여 사용할 수 있습니다
  • 채팅방에서 다른 사람이 올린 이모지도 사용할 수 있습니다

앨범 AI 요약

  • 세션이 종료된 앨범의 요약을 볼 수 있습니다
  • 요약은 세션에 참여한 사용자의 채팅 기반으로 자동 생성됩니다
  • 사용자는 요약을 보고 앨범에 대한 반응을 파악할 수 있습니다

💻 시스템 아키텍처

image image image

inear

기술 공유

🚀 ffmpeg는 stderr로 디버깅을 하는 이유
🚀 HLS 프로토콜에 관한 정리 및 FFmpeg 사용기
🚀 비트는 tsconfig.json이 세 개?
🚀 NestJS 기본 개념 - Modules
🚀 Socket.io 최(강)적화
🚀 도커와 nginx의 사용기
🚀 부하테스트를 해보자

개발 일지

🚀 FSD 사용기, 근데 이제 나만의 규칙을 곁들인
🚀 CICD 구조 수정
🚀 앨범 단위로 스트리밍 하기 (with HLS)
🚀 HLS로 음악 주고받기
🚀 vite + react + typescript 환경에서 path alias 설정
🚀 React Scan이 뭐죠?
🚀 로컬 환경 개발 모드 배포
🚀 앨범 전체를 스트리밍한다고? (with HLS)
🚀 코드의 안정성을 높이기 위해 테스트코드를 작성해보자

트러블 슈팅

🚀 새로고침 시 HLS ERROR
🚀 input 태그에 한글 입력 후, Enter를 누르면 함수가 두번 호출되는 오류
🚀 nginx proxy pass를 바꿨더니 생긴 에러 - 스웨거 인식 문제
🚀 배포 환경에서 클라이언트-서버 WS handshake
🚀 렌더링 범인은 하나!

협업 규칙

🌈 그라운드 룰
🥔 팀원 소개
🔎 코드 & 깃 컨벤션
🌳 깃 branch 전략
📌 노션 문서 저장소

프로젝트 기획

🎨 피그마
🧑‍💻 기획 공유 발표 자료
🎤 2주차 발표 자료
😎 백로그

데일리 스크럼

📝 1주차
📝 2주차
📝 3주차
📝 4주차
📝 5주차

주간 계획서

🗓️ 1주차
🗓️ 2주차
🗓️ 3주차
🗓️ 4주차
🗓️ 5주차

그룹 회고

✨ 1주차
✨ 2주차
✨ 3주차
✨ 4주차


view

Clone this wiki locally