Cloud CDN เป็นส่วนสําคัญของการสนับสนุนเว็บแอปจาก App Hosting คําขอทั้งหมดที่ส่งไปยังแบ็กเอนด์จะผ่าน Cloud CDN ก่อน ระบบจะแสดงเนื้อหาที่แคชไว้ใน CDN กลับไปยังผู้ใช้ทันที โดยข้ามบริการ Cloud Run ที่เรียกใช้โค้ดเซิร์ฟเวอร์ของเว็บแอป ดูข้อมูลเพิ่มเติมเกี่ยวกับข้อดีทั่วไปของ CDN ได้ที่ web.dev
แม้ว่าApp Hostingจะเป็นผู้กำหนดค่า Cloud CDN พื้นฐานและไม่สามารถแก้ไขได้ แต่คุณก็ดำเนินการหลายอย่างเพื่อเพิ่มประสิทธิภาพการแคชได้เพื่อเพิ่มความเร็วในการโหลดหน้าเว็บ ลดเนื้อหาที่ไม่ได้แคชซึ่งมีการเรียกเก็บเงิน และลดการเข้าชม Cloud Run
เนื้อหาที่แคชได้
Cloud CDN จะจัดเก็บคำตอบไว้ในแคชหากเงื่อนไขต่อไปนี้ทั้งหมดเป็นจริง
คำขอเป็น GET
การตอบกลับมีรหัสสถานะเป็น
200
,203
,204
,206
,300
,301
,302
,307
,308
,404
,405
,410
,421
,451
หรือ501
การตอบกลับมีส่วนหัว
Cache-Control
ที่มีคำสั่งmax-age
หรือs-maxage
หรือส่วนหัวExpires
ที่มีการประทับเวลาในอนาคตการตอบกลับมีส่วนหัว
Age
หรือส่วนหัวCache-Control
ที่มีคำสั่งpublic
ที่ชัดเจนการตอบกลับมีขนาดไม่เกิน 10 MiB
และไม่มีเงื่อนไขต่อไปนี้เป็นจริง
การตอบกลับมีส่วนหัว
Set-Cookie
การตอบกลับมีส่วนหัว
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
การตอบกลับมีส่วนหัว
Cache-Control
ที่มีคำสั่งno-store
หรือprivate
คำขอมีส่วนหัว
Cache-Control
ที่มีคำสั่งno-store
คำขอมีส่วนหัว
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 จะแสดงจำนวนไบต์ที่แคชไว้และไม่ได้แคชไว้ซึ่งให้บริการ และมีเครื่องหมายสำหรับแต่ละการเปิดตัว คุณสามารถใช้กราฟนี้เพื่อวัดประสิทธิภาพของการเพิ่มประสิทธิภาพแคช