시스템 디자인 면접은 시니어 개발자 채용의 핵심이다. 정답이 없는 열린 문제다. 면접관은 사고 과정을 본다. 어떻게 문제에 접근하고 트레이드오프를 고려하는지가 중요하다.
문제를 명확하게 정의하는 것부터 시작한다. 요구사항을 확인한다. 사용자 수, 데이터 규모, 지연 시간 요구사항 같은 것들. 가정을 명시하고 면접관과 확인한다.
고수준 설계
먼저 큰 그림을 그린다. 주요 컴포넌트를 식별한다. 클라이언트, 로드 밸런서, 웹 서버, 데이터베이스, 캐시 같은 기본 구성 요소. 데이터 흐름을 설명한다.
세부사항에 빠지지 않도록 주의한다. 면접관이 특정 부분을 깊이 들어가고 싶으면 질문할 것이다. 전체 아키텍처를 먼저 보여준 다음 상세 설계로 넘어간다.
트레이드오프 논의
모든 결정에는 트레이드오프가 있다. SQL vs NoSQL, 동기 vs 비동기, 일관성 vs 가용성. 각 선택의 장단점을 설명한다. 왜 그 결정을 내렸는지 근거를 제시한다.
확장성을 고려한다. 수평 확장, 샤딩, 파티셔닝 전략을 논의한다. 병목 지점을 식별하고 해결 방안을 제시한다.
연습이 답이다
유명한 시스템을 설계해보자. URL 단축기, 채팅 시스템, 뉴스 피드, 검색 엔진. 실제로 그려보고 설명해보자. 연습만이 자신감을 만든다.