แคชเนื้อหาแอป

Cloud CDN เป็นส่วนสําคัญของการสนับสนุนเว็บแอปจาก App Hosting คําขอทั้งหมดที่ส่งไปยังแบ็กเอนด์จะผ่าน Cloud CDN ก่อน ระบบจะแสดงเนื้อหาที่แคชไว้ใน CDN กลับไปยังผู้ใช้ทันที โดยข้ามบริการ Cloud Run ที่เรียกใช้โค้ดเซิร์ฟเวอร์ของเว็บแอป ดูข้อมูลเพิ่มเติมเกี่ยวกับข้อดีทั่วไปของ CDN ได้ที่ web.dev

แม้ว่าApp Hostingจะเป็นผู้กำหนดค่า Cloud CDN พื้นฐานและไม่สามารถแก้ไขได้ แต่คุณก็ดำเนินการหลายอย่างเพื่อเพิ่มประสิทธิภาพการแคชได้เพื่อเพิ่มความเร็วในการโหลดหน้าเว็บ ลดเนื้อหาที่ไม่ได้แคชซึ่งมีการเรียกเก็บเงิน และลดการเข้าชม Cloud Run

เนื้อหาที่แคชได้

Cloud CDN จะจัดเก็บคำตอบไว้ในแคชหากเงื่อนไขต่อไปนี้ทั้งหมดเป็นจริง

  1. คำขอเป็น GET

  2. การตอบกลับมีรหัสสถานะเป็น 200, 203, 204, 206, 300, 301, 302, 307, 308, 404, 405, 410, 421, 451 หรือ 501

  3. การตอบกลับมีส่วนหัว Cache-Control ที่มีคำสั่ง max-age หรือ s-maxage หรือส่วนหัว Expires ที่มีการประทับเวลาในอนาคต

  4. การตอบกลับมีส่วนหัว Age หรือส่วนหัว Cache-Control ที่มีคำสั่ง public ที่ชัดเจน

  5. การตอบกลับมีขนาดไม่เกิน 10 MiB

และไม่มีเงื่อนไขต่อไปนี้เป็นจริง

  1. การตอบกลับมีส่วนหัว Set-Cookie

  2. การตอบกลับมีส่วนหัว Vary ที่มีค่าอื่นที่ไม่ใช่ Accept, Accept-Encoding, Access-Control-Request-Headers, Access-Control-Request-Method, Origin, Sec-Fetch-Dest, Sec-Fetch-Mode, Sec-Fetch-Site, X-Goog-Allowed-Resources, X-Origin, RSC, Next-Router-State-Tree, Next-Router-Prefetch หรือ Next-Router-Segment-Prefetch

  3. การตอบกลับมีส่วนหัว Cache-Control ที่มีคำสั่ง no-store หรือ private

  4. คำขอมีส่วนหัว Cache-Control ที่มีคำสั่ง no-store

  5. คำขอมีส่วนหัว Authorization เว้นแต่การตอบกลับจะมีคำสั่งควบคุมแคชที่ชัดเจน

ปรับแต่งลักษณะการทํางานด้วยคําสั่งการควบคุมแคช

Next.js

Next.js จะตั้งค่าคำสั่งการควบคุมแคชโดยนัยตามปัจจัยหลายประการ แต่คุณสามารถลบล้างค่าเหล่านี้ได้โดยตั้งค่าส่วนหัวด้วยตนเองในไฟล์next.config.js เช่น วิธีตรวจสอบว่าหน้าเว็บไม่ได้แคชไว้ใน Cloud CDN

  /** @type {import('next').NextConfig} */
  const nextConfig = {
      headers: async () => [{
          source: "/YOUR_PRIVATE_PAGE",
          headers: [{
              key: "Cache-Control",
              value: "private"
          }],
      }],
  };

Angular

Angular SSR ไม่ได้ตั้งค่าคำสั่ง cache-control ที่ชัดเจนตั้งแต่แกะกล่อง คุณสามารถเพิ่มส่วนหัวของคุณเองได้โดยระบุส่วนหัว Cache-Control ในเส้นทางของเซิร์ฟเวอร์ เช่น หากต้องการอนุญาตให้ Cloud CDN แคชหน้าเว็บทั้งหมดเป็นเวลา 1 ชั่วโมง ให้ทำดังนี้

import { RenderMode, ServerRoute } from '@angular/ssr';

export const serverRoutes: ServerRoute[] = [
  {
    path: '**',
    renderMode: RenderMode.Prerender,
    headers: {
      'Cache-Control': 'public, max-age=3600',
    }
  }
];

หรือหากต้องการให้ระบบไม่แคชหน้าเว็บที่เฉพาะเจาะจง ให้ทำดังนี้

import { RenderMode, ServerRoute } from '@angular/ssr';

export const serverRoutes: ServerRoute[] = [
  // ... other routes
  {
    path: 'YOUR_PRIVATE_PAGE',
    renderMode: RenderMode.Server,
    headers: {
      'Cache-Control': 'private',
    }
  }
];

คำสั่งที่เคารพ

อินสแตนซ์ Cloud CDN ของ Firebase App Hosting ปฏิบัติตามคำสั่งควบคุมแคชต่อไปนี้

คำสั่ง คำขอ การตอบสนอง
no-store เมื่ออยู่ในคำขอ ระบบจะไม่แคชคำตอบ ระบบจะไม่แคชการตอบกลับที่มี no-store
no-cache ระบบจะไม่สนใจคําสั่ง no-cache request เพื่อไม่ให้ไคลเอ็นต์เริ่มหรือบังคับให้ตรวจสอบแหล่งที่มาอีกครั้ง ระบบจะแคชการตอบกลับที่มี no-cache แต่ต้องตรวจสอบกับต้นทางอีกครั้งก่อนแสดง
public ไม่มี คำสั่งนี้ไม่จำเป็นสำหรับการแคชได้ แต่แนวทางปฏิบัติแนะนำคือให้ใส่คำสั่งนี้สำหรับเนื้อหาที่ควรได้รับการแคชโดยพร็อกซี
private ไม่มี Cloud CDN จะไม่แคชการตอบกลับที่มีคําสั่ง private แม้ว่าการตอบกลับนั้นจะถือว่าแคชได้ก็ตาม ลูกค้า (เช่น เบราว์เซอร์) อาจยังคงแคชผลลัพธ์ไว้ ใช้ no-store เพื่อป้องกันการแคชคำตอบทั้งหมด
max-age=SECONDS ระบบจะละเว้นคำสั่งคำขอ max-age ระบบจะแสดงการตอบกลับที่แคชไว้ราวกับว่าไม่มีส่วนหัวนี้ในคำขอ ระบบจะแคชการตอบกลับที่มีคําสั่ง max-age ไว้สูงสุด SECONDS ที่กําหนด
s-maxage=SECONDS ไม่มี ระบบจะแคชการตอบกลับที่มีคําสั่ง s-maxage ไว้สูงสุด SECONDS ที่กําหนด หากมีทั้ง max-age และ s-maxage อยู่ด้วย Cloud CDN จะใช้ s‑maxage การตอบกลับที่มีคำสั่งนี้จะไม่แสดงข้อมูลเก่า s-max-age (ขีดกลาง 2 ตัว) ไม่ถูกต้องสำหรับวัตถุประสงค์ในการแคช
max-stale=SECONDS คำสั่ง max-stale request กำหนดความล้าสมัยสูงสุด (เป็นวินาที) ที่ไคลเอ็นต์ยินดีรับ Cloud CDN จะดำเนินการตามคำสั่งนี้และแสดงการตอบกลับที่แคชไว้ซึ่งล้าสมัยเฉพาะในกรณีที่ความล้าสมัยของการตอบกลับน้อยกว่าคำสั่ง max-stale มิเช่นนั้น ระบบจะตรวจสอบอีกครั้งก่อนที่จะให้บริการตามคำขอ ไม่มี
stale-while-revalidate=SECONDS ไม่มี ระบบจะแสดงคำตอบที่มี stale-while-revalidate แก่ไคลเอ็นต์เป็นเวลาสูงสุด SECONDS ขณะที่การยืนยันอีกครั้งเกิดขึ้นแบบไม่พร้อมกัน
must-revalidate ไม่มี การตอบกลับที่มี must-revalidate จะได้รับการยืนยันอีกครั้งกับเซิร์ฟเวอร์ต้นทางหลังจากหมดอายุ การตอบกลับที่มีคำสั่งนี้จะไม่แสดงข้อมูลเก่า
proxy-revalidate การตอบกลับที่มี proxy-revalidate จะได้รับการยืนยันอีกครั้งกับเซิร์ฟเวอร์ต้นทางหลังจากหมดอายุ การตอบกลับที่มีคำสั่งนี้จะไม่แสดงข้อมูลเก่า
no-transform ไม่มี Cloud CDN จะไม่ใช้การเปลี่ยนรูปแบบ

วัดการเข้าชมที่แคชไว้และไม่ได้แคชไว้

กราฟ "Cloud CDN - แบนด์วิดท์ขาออก" ในแท็บการใช้งานของคอนโซล App Hosting จะแสดงจำนวนไบต์ที่แคชไว้และไม่ได้แคชไว้ซึ่งให้บริการ และมีเครื่องหมายสำหรับแต่ละการเปิดตัว คุณสามารถใช้กราฟนี้เพื่อวัดประสิทธิภาพของการเพิ่มประสิทธิภาพแคช