Skip to content

yiseungyun/web27-Preview

 
 

Repository files navigation

✨ Preview


면접 연습을 하고 싶은데.. 🧐
다른 사람과 함께 할 수 없을까? 👥

✨ Preview에서 면접 연습 시작하자! ✨



📣 핵심 기능

WebRTC 기반으로 화상회의 기능을 구현해서 면접 스터디를 할 수 있습니다. 1~5명까지 스터디룸에 입장할 수 있게 설정하였고, 인원 수에 맞춰 Mesh 방식을 택해 클라이언트 간 p2p 통신을 할 수 있게 구현했습니다.

스터디룸 생성

세션_생성

  • 만들어둔 질문지/저장된 질문지 선택
  • 스터디룸 이름 설정 및 인원 수 선택
  • 스터디룸의 공개/비공개 여부 선택
  • 세션을 생성하게 되면 자신의 비디오와 닉네임을 설정하고 입장

화상회의

_.mp4
  • 1~5명까지 정해진 인원 수에 따라 화상회의
  • 비디오/오디오 제어 가능
  • 말하는 사람에게 테두리 효과
  • 리액션 기능

면접 스터디

_.mp4
  • 선택한 질문지를 통해 면접 스터디
  • 질문을 하나씩 넘겨가며 돌아가며 답변할 수 있는 환경 제공
  • 방장이 질문을 넘기고 이전 질문으로도 돌아갈 수 있게 설정

스터디 채널

_.mp4
  • 스터디 채널 페이지에서 다른 사람이 만들어둔 스터디룸에 입장
  • 입장 전 카메라 미리보기와 닉네임 설정을 통해 원하는대로 설정 후 입장

면접 질문지 생성 및 공유

  • 원하는 카테고리에 따라 면접 질문지 생성 가능
  • 면접 질문지 공유와 스크랩을 통해 다른 사람도 이용가능하게 설정
  • 사용량에 따라 인기 질문지 확인 가능

🧩 설계

시스템_아키텍처

🛠 기술 스택

Category Stack
Frontend React React Query React Router TypeScript Vite TailwindCSS Zustand
Backend Nginx NestJS TypeScript Redis MySQL Node.js TypeORM
Common WebRTC pnpm ESLint Husky Prettier
DevOps Docker NCP
CI/CD GitHub Actions
Etc Figma Notion

🥊 기술적 경험

저희들의 휘발되기엔 아까운 우리 팀의 개발 경험입니다! 더 자세한 경험들은 이곳 에서 확인하실 수 있습니다.

[BE] Coturn 설치 및 config 파일 수정

coturn은 WebRTC에서 NAT와 방화벽 문제를 해결하기 위해 사용되는 오픈소스 TURN/STUN 서버입니다. 설치 후 /etc/turnserver.conf 파일에서 listening-port, external-ip, min-port, verbose 등을 설정하여 서버 동작을 최적화했습니다. 인증 방식(lt-cred-mech)과 사용자 계정을 설정해 보안을 강화하며, NAT 뒤에서의 통신을 지원하도록 external-ip를 공인 IP와 매핑했습니다.

작성자: 송수민

🔗 coturn 설치 및 config 파일 수정

[BE] 트랜잭션 최적화: queryRunner는 만능이 아니다

프로젝트에서 데이터 일관성을 보장하기 위해 질문지 생성과 질문 삭제 로직에서 트랜잭션이 필요했습니다. 초기에 @Transactional()을 사용해 메서드 단위로 트랜잭션을 구현했고, 불필요한 트랜잭션 범위를 없애기 위해 queryRunner로 대체해서 개선했습니다. k6를 이용한 부하 테스트를 진행했고, 그 결과 queryRunner를 사용하는 것이 무조건 성능 개선을 보장하는 것은 아니며, 상황에 따라 적합한 방식을 선택하는 것이 중요하다는 것을 알게 되었습니다.

작성자: 송수민

🔗 트랜잭션 최적화: queryRunner는 만능이 아니다

[FE] 토큰 재발급부터 요청 재시도까지 한번에 axios interceptor

액세스 토큰 만료시 401 에러를 Axios Interceptor로 일괄 처리하여 자동으로 토큰 재발급 및 요청 재시도 구현했습니다. 토큰 재발급 실패시 세션 만료로 간주하여 로그인 페이지로 리다이렉트하는 일관된 에러 처리 구축해보았습니다. 중앙화된 토큰 관리가 되니, 코드 중복 제거 및 유지보수성이 향상되었고, 개별 컴포넌트의 토큰 관리 부담이 줄었습니다.

작성자: 서정우

🔗 axios interceptor를 사용한 401에러 일관적 처리

[FE] 카메라 인디케이터 항상 켜져있던 문제 해결하기

카메라 끄기시 인디케이터 계속 켜지는 UX 문제를 track.stop()으로 해결하고, useRef+useState로 스트림 관리 구조 개선했습니다. 이 과정에서 발생한 다른 참가자 화면 멈춤 문제를 PeerConnections 업데이트로 해결했고, 결과적으로 카메라 끄기시 인디케이터도 꺼지고 참가자간 동기화도 잘 되는 안정적인 기능이 되었습니다.

작성자: 서정우

🔗 카메라 인디케이터 항상 켜져있던 문제 해결하기

[BE] Facade 패턴으로 redis-om 엔티티에 도메인 로직 결합하기

Redis에서 복잡한 객체를 직렬화/역직렬화하는 반복 작업의 문제를 인식하였습니다. 그래서 여러 해결 방안을 시도하고 각각의 장단점을 분석하는 과정을 통해, DDD의 개념을 완전히 도입하기보다, 도메인 로직 분리라는 핵심 아이디어만 채택하여서 문제를 해결했습니다. 그 과정에서 결과적으로 Facade 패턴을 자연스럽게 도출이 되었습니다.

작성자: 김찬우

🔗 Facade 패턴으로 redis-om 엔티티에 도메인 로직 결합하기

[BE] 협업을 위한 더러운 코드

깔끔한 코드를 만들기 위해 과도한 리팩토링을 시도했습니다. 협업보다 개인의 코드 품질 추구가 우선시되고 있었고, 멘토링을 통해 코드의 길이보다 구조와 역할이 더 중요함을 깨달았습니다. 절대적인 규칙이나 패턴을 맹목적으로 따르지 않고 상황에 맞는 판단의 중요성을 배웠습니다.

작성자: 김찬우

🔗 협업을 위한 더러운 코드

[FE] useSession 테스트 코드 작성하기

핵심 기능인 화상회의에 관한 코드가 모여있는 useSession 훅이 너무 많은 일을 하고 있었습니다. 분리해서 리팩토링을 진행하고 싶었는데 잘못하다가 여태까지 구현했던 것에 문제가 생길거 같았고, 클라이언트 측 동작을 테스트하기 위해 모킹을 이용해 테스트 코드를 작성했습니다. 이후 해당 훅을 분리하는 과정에서 테스트 코드를 통해 오류 없이 리팩토링을 진행할 수 있었고, 테스트 코드의 필요성에 대해 배웠습니다.

작성자: 이승윤

🔗 useSession 테스트 코드 작성하기

[FE] 상대방의 비디오가 보이지 않던 문제 해결하기

내 비디오는 보이는데 상대방의 비디오가 보이지 않는 문제가 있었습니다. 소켓 연결부터 피어의 상태관리까지 디버깅 코드를 넣어 관찰한 결과 디버깅 코드는 문제가 없었고, 비디오 스트림을 처리하는 코드를 보고 잘못된 방식으로 처리하고 있다는 것을 깨달았습니다. 문제가 생긴 부분을 체크하기 위해 단계별로 어디가 문제인지 찾아가며 문제를 찾는 범위를 좁히는 것의 중요성을 배웠습니다.

작성자: 이승윤

🔗 상대방의 비디오가 보이지 않던 문제 해결하기


👋 팀원 소개

김찬우 서정우 송수민 이승윤
WEB BE WEB FE WEB BE WEB FE

🐧 김찬우

'함께 자라는 개발도 잘하는 사람'이 되고 싶은 그저 프로그래밍이 재밌는 사람입니다. 펭귄처럼 바보라도 당당하게 호기심 있게 되고 싶습니다!

💣 서정우

멈추지 않는 기술의 변화를 즐기는 개발자가 되고 싶은 서정우입니다!

🐬 송수민

안녕하세요! 저는 수영장에 가거나 차 마시는 것을 좋아하는 백엔드 개발자 송수민입니다.

🦄 이승윤

안녕하십니까마귀. 저는 즐겁게 개발하는 걸 좋아합니다! 🎉


About

실시간 화상 면접 스터디 ☃️

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • TypeScript 97.5%
  • JavaScript 1.4%
  • Other 1.1%