뒤로-앞으로 캐시로 Yahoo! JAPAN News, 모바일 수익 9% 증가

Yuriko Hirota
Yuriko Hirota

뒤로-앞으로 캐시 (또는 bfcache)는 즉시 앞뒤로 탐색할 수 있는 브라우저 최적화 기능입니다. 특히 앞뒤로 탐색이 많은 웹사이트에서 사용자의 탐색 환경을 크게 개선합니다.

bfcache에 관한 web.dev 도움말

Yahoo! 일본에서 가장 인기 있는 뉴스 플랫폼 중 하나인 JAPAN News는 bfcache 적중률을 개선하기 위해 공동으로 노력한 결과, 사용자 환경과 비즈니스가 크게 개선되었습니다. 구체적으로, 진행한 A/B 테스트 결과 bfcache를 사용하는 페이지의 광고 수익이 9% 증가한 것으로 나타났습니다.

이 사례에서는 Yahoo! JAPAN News에서 bfcache 차단을 삭제했으며 bfcache가 사용자 환경을 대폭 개선한 방법을 설명합니다.

bfcache 차단기 삭제

bfcache는 Chrome 86부터 제공되었으며 모든 최신 브라우저에서도 사용할 수 있습니다. 하지만 bfcache를 최대한 활용하려면 웹사이트에서 잠재적인 차단 프로그램을 삭제해야 합니다. Yahoo!에서 JAPAN 뉴스가 직면한 문제는 다음과 같습니다.

  1. unload 핸들러 사용
  2. Cache-control 헤더에서 no-store 지시문을 사용합니다.

Chrome DevTools > 애플리케이션 > 뒤로/앞으로 캐시로 이동하여 웹사이트의 주요 차단 요소를 확인할 수 있습니다. 또는 notRestoredReasons API를 사용하여 현장의 실제 사용을 기반으로 차단 요소를 더 포괄적으로 확인할 수 있습니다.

다음은 Yahoo! JAPAN News에서 차단 요소를 삭제했습니다.

CCNS는 어떠한 경우에도 캐시되어서는 안 되는 페이지를 위한 것입니다. 단, CCNS가 있는 페이지는 CDN 에지 서버 및 로컬 캐시를 비롯한 캐싱 기술의 이점을 누리지 못합니다.

CCNS 헤더가 있는 경우 웹사이트에 적합한 Cache-control 전략을 논의할 수 있는 좋은 기회입니다. no-storeno-cache의 주요 차이점은 다음과 같습니다.

Cache-control: no-store Cache-control: no-cache
  • 응답을 캐시에 저장할 수 없습니다.
  • 따라서 모든 요청에서 응답이 완전히 가져옵니다.
  • 비공개 응답에 사용해야 합니다.
  • 응답은 매번 사용하기 전에 서버에서 재검증되는 한 캐시에 저장할 수 있습니다.
  • 매번 재검증하려는 공개 응답이어야 합니다 (예: 뉴스 웹사이트의 홈페이지). 하지만 매우 짧은 캐시 시간으로도 성능을 개선하고 기본 서버에서 작업을 오프로드할 수 있습니다.

cache-control 옵션에 대해 자세히 알아보려면 cache-control 플로우 차트를 검토하세요.

효과를 입증하기 위한 A/B 테스트

bfcache의 영향을 측정하기 위해 Yahoo! JAPAN News는 2주 동안 A/B 테스트를 진행했습니다. 한 그룹에는 bfcache 수정사항이 적용된 페이지 버전을, 다른 그룹에는 bfcache를 사용할 수 없는 페이지 버전을 게재했습니다. 테스트에서 유의미한 결과를 얻기 위해 트래픽이 많은 URL 경로를 테스트했습니다. 페이지 간에 시각적 또는 기능적 차이는 없었습니다.

다음은 bfcache를 사용한 웹사이트와 bfcache를 사용하지 않은 웹사이트를 비교한 동영상입니다. bfcache가 사용 설정된 웹사이트는 뒤로 또는 앞으로 탐색하는 동안 훨씬 더 빠르게 로드됩니다.

특히 모바일 기기에서 bfcache를 사용 설정한 그룹의 페이지 조회수와 광고 수익이 크게 증가한 것이 고무적입니다.

다음은 Yahoo!에서 관찰한 영향에 관한 세부정보입니다. bfcache A/B 테스트를 사용한 JAPAN 뉴스 자세한 내용은 우수사례를 참고하세요.

측정항목 상승 폭(%)(모바일) 상승 폭(%)(데스크톱)
bfcache 적중률 54.03포인트 상승 (0.04% → 54.07%) +47.28포인트 (0.02% → 47.30%)
페이지 조회 +2.26% +0.65%
광고 수익 +9.0% +0.6%

bfcache를 사용하면 페이지 간에 뒤로/앞으로 탐색이 즉시 이루어지므로 사용자가 페이지에 더 오래 머무르게 되어 광고 조회수가 증가하고 광고 수익이 늘어납니다.

원활한 사용자 환경

페이지가 즉시 로드되면 탐색이 더 원활하게 느껴집니다.

Yahoo! JAPAN News의 주요 사용자 여정 중 하나는 여러 기사를 읽는 것입니다.

  1. 도움말 목록을 방문하세요.
  2. 읽으려는 기사를 클릭합니다.
  3. 완료되면 도움말 목록으로 돌아갑니다.
  4. 다른 도움말을 클릭하여 읽습니다.

bfcache 이전에는 사용자가 기사 읽기를 완료하면 기사 목록 페이지가 다시 로드될 때까지 기다려야 했습니다. 이는 목록으로 빠르게 돌아가서 읽을 다른 기사를 선택하려는 사용자에게 불편을 줄 수 있습니다.

뒤로 탐색 중 불편을 야기하는 또 다른 요소는 스크롤 위치였습니다. 실제로는 브라우저가 뒤로 탐색이 발생할 때 스크롤 위치를 복원하려고 시도합니다. 하지만 동적으로 추가된 광고나 기타 레이아웃 변경으로 인해 스크롤 위치가 잘못 복원될 수 있습니다. 이로 인해 사용자에게 혼란이 발생하거나 페이지가 중단될 수 있습니다.

이 문제는 뒤로 탐색이 bfcache를 기반으로 하면 해결됩니다. 스크롤 위치가 즉시 올바르게 복원됩니다.

뒤로 탐색의 필름 스트립 2개 위는 bfcache로 처리되는 필름 스트립으로 0.3초가 소요되는 반면, 아래는 bfcache 없이 처리되는 동일한 프로세스로 3.3초가 소요됩니다.

이제 bfcache를 사용하면 사용자 여정에서 발생하는 불편이 사라집니다. 사용자는 기사 목록 페이지가 로드될 때까지 기다리지 않고도 기사 목록 페이지로 즉시 이동하여 읽을 다른 기사를 선택할 수 있습니다.

사용자가 한 도움말에서 다른 도움말로 직접 탐색했다가 다시 돌아가도 마찬가지입니다.

bfcache 유무와 관계없이 도움말에서 도움말 목록 페이지로 뒤로 탐색하는 흐름을 보여주는 애니메이션 이미지입니다.
bfcache를 사용하면 뒤로 탐색이 더 빠르고 스크롤 위치가 정확하게 유지됩니다. bfcache가 없으면 이러한 개선사항이 보장되지 않습니다.

요약하자면 Yahoo! JAPAN 뉴스에는 다음이 포함됩니다.

  • 페이지 조회수 증가: 페이지가 bfcache로 캐시되면 사용자가 웹사이트 내에서 탐색할 가능성이 높아졌습니다.
  • 수익 증가: 세션당 페이지 조회수가 증가하여 광고 노출이 증가하여 bfcache가 없는 테스트 그룹에 비해 모바일에서 수익이 9% 증가했습니다.

지금 bfcache 구현

요컨대 bfcache를 사용하면 웹사이트를 즉시 로드할 수 있을 뿐만 아니라 전반적인 사용자 환경의 불편을 줄이고 웹사이트 내 참여도를 높일 수 있습니다.

Chrome팀은 bfcache 차단기, 특히 bfcache가 사용되지 않는 일반적인 이유로 표시된 이유를 지속적으로 살펴보고 있습니다. 향후 이러한 조치로 bfcache 사용이 방지되지 않을 수도 있지만 그때까지 기다릴 필요는 없습니다. 지금 bfcache 차단 프로그램을 살펴보고 이러한 일반적인 패턴 (및 덜 일반적인 다른 패턴)을 피하면 bfcache의 이점을 누릴 수 있습니다.