네트워크

CloudFlare - 정적 캐싱 vs 동적 캐싱

_tera_ 2023. 6. 13. 15:09

https://www.cloudflare.com/learning/cdn/caching-static-and-dynamic-content/


정적 컨텐츠 Static Content

  • 서버에 저장되어 사용자에게 전달될 때마다 동일하게 유지되는 모든 파일
  • HTML 파일과 이미지

 

동적 컨텐츠 Dynamic content

  • 방문 시간, 위치, 디바이스 등 사용자 고유의 요인에 따라 변경되는 콘텐츠
  • 동적 웹페이지는 모든 사람에게 동일하게 표시되지 않으며, 사용자가 웹페이지와 상호 작용할 때 변경
  • 정적 HTML 파일로 저장 X
  • 서버 측 스크립트가 사용자 상호 작용이나 사용자 로그인 등의 이벤트에 대한 응답으로 HTML 파일을 생성하고 웹 브라우저로 HTML 파일을 전송 👉캐시가 아닌 원본 서버에서 제공

정적 캐싱 

  • 콘텐츠가 제공될 때 캐시가 정적 파일의 사본을 저장하여 사용자에게 더 가깝고 더 빠르게 전달
  • 브라우저와 CDN은 정적 콘텐츠를 일정 기간 동안 캐싱하여 콘텐츠 요청이 계속되는 한 사용자에게 제공
  • 정적 콘텐츠는 시간이 지나도 변경되지 않으므로 동일한 파일을 여러 번 사용자에게 전송할 수 있기 때문에 가능

동적 캐싱

  • 동적 콘텐츠는 페이지의 콘텐츠를 변경하는 스크립트에 의해 생성
  • 오리진 서버가 아닌 CDN 캐시에서 스크립트를 실행해서 캐시에서 동적 콘텐츠를 생성하고 전송 가능👉클라이언트 요청에 대한 응답 시간이 단축되고 동적 웹페이지의 속도가 빨라짐

동적 웹페이지 속도 향상 방법

 

1. 동적 콘텐츠 압축

  • 원본 서버에서 생성된 동적 콘텐츠를 압축
  • 콘텐츠는 여전히 캐시가 아닌 원본 서버에서 가져오지만 생성된 HTML 파일의 크기가 훨씬 작아져 클라이언트 디바이스에 더 빨리 도달

2. ESI(Edge Side Includes)

  • 동적 웹 페이지의 특정 요소만 동적으로 유지 👉 HTML 코드가 중복
  • 웹페이지에서 동적 콘텐츠가 표시되는 위치를 지정하는 마크업 언어인 ESI(Edge Side Includes)를 개발                (ESI는 일부 CDN에서 사용 중이지만 웹 표준을 관리하는 조직인 W3C에서는 아직 승인X)
  • ESI 태그가 있는 콘텐츠는 다른 곳에서 가져오고 나머지 웹페이지의 콘텐츠는 캐시
  • 각 사용자에 대해 전체 페이지를 생성해야 하는 경우보다 훨씬 더 빠르게 로드