icon

안동민 개발노트

13장 : 실무 네트워크 인프라

CDN


지금까지 네트워크의 계층별 동작 원리와 프로토콜을 살펴보았습니다. 이제 실제 서비스를 운영할 때 필수적인 네트워크 인프라 구성 요소를 다루겠습니다. 첫 번째는 CDN(Content Delivery Network)입니다.


왜 CDN이 필요한가

서울에 있는 서버에서 브라질 사용자에게 웹 페이지를 보낸다고 합시다. 빛의 속도로도 서울과 상파울루 간 왕복 시간은 약 300ms입니다.

Excalidraw 씬을 불러오는 중입니다.

브라질 사용자 기준으로 서울 서버 직통과 상파울루 엣지(캐시 히트) 경로의 RTT/핸드셰이크 지연을 비교한 흐름도입니다.

CDN은 전 세계에 분산된 엣지 서버에 콘텐츠의 복사본을 캐시하고, 사용자에게 가장 가까운 서버에서 응답합니다.


CDN의 동작 원리

Excalidraw 씬을 불러오는 중입니다.

DNS 질의 후 상파울루 엣지로 라우팅되고, 캐시 히트/미스에 따라 즉시 응답 또는 서울 오리진 조회 후 캐시 저장으로 이어지는 CDN 요청 흐름입니다.

캐시의 유효 기간은 HTTP의 Cache-Control 헤더로 제어합니다.

CDN 캐시 제어 헤더
Cache-Control: max-age=86400       → 브라우저 + CDN 24시간
Cache-Control: s-maxage=3600       → CDN만 1시간
Cache-Control: no-cache            → 매번 오리진에 검증
Cache-Control: no-store            → 캐시 금지
Cache-Control: stale-while-revalidate=60  → 만료 후 60초간
                                          캐시 응답 + 백그라운드 갱신

캐시 무효화 전략

코드를 배포했을 때 CDN 캐시가 갱신되지 않으면, 사용자는 여전히 이전 버전을 받습니다.

전략방식장점단점
파일명 해싱main.abc123.js가장 확실, 자동화빌드 도구 필요
퍼지(Purge)API로 캐시 삭제즉시 적용수동, 전파 시간
캐시 태그태그별 그룹 무효화유연한 관리CDN별 구현 다름
단기 TTLmax-age=60자동 갱신캐시 효율 감소
버전 쿼리스트링?v=2간단일부 CDN 무시

대표 CDN 서비스

CDN 비교
서비스             특징                   무료 플랜     용도
─────────────────────────────────────────────────────────────────
Cloudflare        CDN+DDoS+WAF+DNS 통합       ✓         범용
AWS CloudFront    AWS 생태계 통합             ✗         (프리티어) AWS 서비스
Akamai            원조 CDN, 최대 PoP          ✗         대기업
Fastly            실시간 퍼지, Edge           ✗         API/동적
Vercel/Netlify    프론트엔드 배포 통합        ✓         정적 사이트

CDN은 정적 파일에만 유용한 것이 아닙니다. API 응답 캐싱, 엣지에서의 요청 조작(Edge Functions), 이미지 최적화(리사이징, 포맷 변환) 등 점점 더 많은 로직이 엣지로 이동하고 있습니다.

다음 절에서는 트래픽을 여러 서버로 분배하는 로드 밸런서를 다루겠습니다.

목차