ذخیره سازی توسط کارگر سرویس و ذخیره سازی HTTP

مزایا و معایب استفاده از منطق انقضا ثابت یا متفاوت در لایه‌های کش سرویس و کش HTTP.

در حالی که کارگران سرویس و PWA در حال تبدیل شدن به استانداردهای برنامه های کاربردی وب مدرن هستند، کش منابع پیچیده تر از همیشه شده است. این مقاله تصویر بزرگی از کش مرورگر را پوشش می دهد، از جمله:

  • موارد استفاده و تفاوت‌های بین کش سرویس کارگر و حافظه پنهان HTTP.
  • مزایا و معایب استراتژی‌های مختلف انقضای حافظه پنهان در مقایسه با استراتژی‌های معمول ذخیره‌سازی HTTP.

در سطح بالا، مرورگر هنگام درخواست منبع از ترتیب ذخیره سازی زیر پیروی می کند:

  1. کش سرویس : کارگر سرویس بررسی می‌کند که آیا منبع در حافظه پنهان است و تصمیم می‌گیرد که آیا خود منبع را بر اساس استراتژی‌های ذخیره‌سازی برنامه‌ریزی‌شده‌اش برگرداند یا خیر. توجه داشته باشید که این به طور خودکار اتفاق نمی افتد. شما باید یک کنترل کننده رویداد واکشی در سرویس‌کار خود ایجاد کنید و درخواست‌های شبکه را رهگیری کنید تا درخواست‌ها به جای شبکه، از حافظه پنهان کارمند سرویس ارائه شوند.
  2. حافظه پنهان HTTP (همچنین به عنوان کش مرورگر نیز شناخته می شود) : اگر منبع در حافظه پنهان HTTP یافت شود و هنوز منقضی نشده باشد، مرورگر به طور خودکار از منبع موجود در حافظه پنهان HTTP استفاده می کند.
  3. سمت سرور: اگر چیزی در کش سرویس یا کش HTTP یافت نشد، مرورگر برای درخواست منبع به شبکه می رود. اگر منبع در یک CDN ذخیره نشده باشد، درخواست باید تا آخر به سرور مبدا برگردد.

جریان ذخیره سازی

ذخیره سازی لایه ها

کارمند سرویس در حال ذخیره سازی

یک سرویس‌گر درخواست‌های HTTP نوع شبکه را رهگیری می‌کند و از استراتژی ذخیره‌سازی برای تعیین منابعی که باید به مرورگر بازگردانده شوند، استفاده می‌کند. کش Service Worker و کش HTTP هدف کلی یکسانی دارند، اما کش سرویس‌کار قابلیت‌های ذخیره‌سازی بیشتری را ارائه می‌کند، مانند کنترل دقیق بر روی دقیقاً آنچه در حافظه پنهان و نحوه ذخیره‌سازی انجام می‌شود.

کنترل کش سرویس کارگر

یک سرویس دهنده درخواست های HTTP را با شنوندگان رویداد (معمولا رویداد fetch ) رهگیری می کند. این قطعه کد منطق یک استراتژی کش کردن Cache-First را نشان می دهد.

نموداری که نشان می‌دهد چگونه کارکنان خدمات درخواست‌های HTTP را رهگیری می‌کنند

برای جلوگیری از اختراع مجدد چرخ، استفاده از Workbox به شدت توصیه می شود. برای مثال، می‌توانید مسیرهای URL منبع را با یک خط کد regex ثبت کنید .

import {registerRoute} from 'workbox-routing';

registerRoute(new RegExp('styles/.*\\.css'), callbackHandler);

استراتژی‌های ذخیره‌سازی حافظه موقت و موارد استفاده از کارکنان خدمات

جدول بعدی، استراتژی‌های رایج ذخیره‌سازی سرویس‌دهنده و زمانی که هر استراتژی مفید است را نشان می‌دهد.

استراتژی ها منطق طراوت موارد استفاده کنید
فقط شبکه محتوا باید همیشه به روز باشد.
  • پرداخت ها و پرداخت ها
  • صورت های تراز
بازگشت شبکه به حافظه پنهان ترجیحاً محتوای تازه سرو شود. اما اگر شبکه از کار بیفتد یا ناپایدار باشد، ارائه محتوای کمی قدیمی قابل قبول است.
  • داده های به موقع
  • قیمت ها و نرخ ها (نیاز به سلب مسئولیت)
  • وضعیت های سفارش
قدیمی-در حالی که-تأیید مجدد ارائه فوراً محتوای کش اشکالی ندارد، اما در آینده باید از محتوای ذخیره شده به روز شده استفاده شود.
  • فیدهای خبری
  • صفحات لیست محصولات
  • پیام ها
ابتدا کش، به شبکه برگردید محتوا غیر بحرانی است و می‌تواند از حافظه پنهان برای افزایش عملکرد استفاده شود، اما کارمند سرویس باید هر از گاهی برای به‌روزرسانی‌ها بررسی کند.
  • پوسته های برنامه
  • منابع مشترک
فقط کش محتوا به ندرت تغییر می کند.
  • محتوای ثابت

مزایای اضافی ذخیره سازی کش توسط سرویسکار

علاوه بر کنترل دقیق منطق ذخیره‌سازی، ذخیره‌سازی سرویس‌کار نیز فراهم می‌کند:

  • حافظه و فضای ذخیره سازی بیشتر برای مبدا شما: مرورگر منابع حافظه پنهان HTTP را بر اساس مبدأ تخصیص می دهد. به عبارت دیگر، اگر چندین ساب دامنه دارید، همه آنها حافظه پنهان HTTP یکسانی دارند. هیچ تضمینی وجود ندارد که محتوای مبدا/دامنه شما برای مدت طولانی در حافظه پنهان HTTP باقی بماند. به عنوان مثال، یک کاربر ممکن است کش را با پاک کردن دستی از رابط کاربری تنظیمات مرورگر، یا راه‌اندازی بارگذاری مجدد سخت در صفحه، پاک کند. با یک کش سرویس، احتمال بیشتری دارید که محتوای کش شما در حافظه پنهان بماند. برای اطلاعات بیشتر به ذخیره سازی دائمی مراجعه کنید.
  • انعطاف‌پذیری بیشتر با شبکه‌های ورقه‌ای یا تجربه‌های آفلاین: با حافظه پنهان HTTP فقط یک انتخاب باینری دارید: یا منبع ذخیره شود یا نه. با ذخیره‌سازی پنهان سرویس‌دهنده، می‌توانید «سکسکه‌های» کوچک را بسیار آسان‌تر کاهش دهید (با استراتژی «بنه-در حالی که-تأیید مجدد»)، یک تجربه آفلاین کامل (با استراتژی «فقط حافظه پنهان») یا حتی چیزی در این بین، مانند رابط‌های کاربری سفارشی‌شده با بخش‌هایی از صفحه که از حافظه پنهان سرویس‌کار می‌آیند و برخی از بخش‌ها حذف می‌شوند (با استراتژی «Set catch handler») در صورت لزوم.

ذخیره HTTP

اولین باری که مرورگر یک صفحه وب و منابع مرتبط را بارگیری می کند، این منابع را در حافظه پنهان HTTP خود ذخیره می کند. کش HTTP معمولاً به طور خودکار توسط مرورگرها فعال می شود، مگر اینکه کاربر نهایی آن را به صراحت غیرفعال کرده باشد.

استفاده از کش HTTP به معنای تکیه بر سرور برای تعیین زمان و مدت زمان کش کردن یک منبع است.

انقضای کش HTTP را با هدرهای پاسخ HTTP کنترل کنید

هنگامی که یک سرور به درخواست مرورگر برای منبع پاسخ می دهد، سرور از هدرهای پاسخ HTTP استفاده می کند تا به مرورگر بگوید چه مدت باید منبع را در حافظه پنهان نگه دارد. سرصفحه‌های پاسخ را ببینید: وب سرور خود را برای کسب اطلاعات بیشتر پیکربندی کنید .

استراتژی های ذخیره سازی HTTP و موارد استفاده

کش HTTP بسیار ساده تر از کش کردن سرویس دهنده است، زیرا کش HTTP فقط با منطق انقضای منابع مبتنی بر زمان (TTL) سروکار دارد. ببینید کدام مقادیر سرصفحه پاسخ را باید استفاده کنید؟ و خلاصه برای کسب اطلاعات بیشتر در مورد استراتژی های ذخیره سازی HTTP.

طراحی منطق انقضای حافظه پنهان

این بخش مزایا و معایب استفاده از منطق انقضای منسجم را در لایه‌های کش سرویس و کش HTTP و همچنین مزایا و معایب منطق انقضای جداگانه در این لایه‌ها را توضیح می‌دهد.

اشکال زیر نشان می دهد که چگونه کش سرویس و کش HTTP در سناریوهای مختلف عمل می کنند:

منطق انقضا ثابت برای تمام لایه های کش

برای نشان دادن مزایا و معایب، به 3 سناریو نگاه خواهیم کرد: بلند مدت، میان مدت و کوتاه مدت.

سناریوها کش طولانی مدت کش میان مدت کش کوتاه مدت
استراتژی ذخیره سازی کارکنان خدمات کش، بازگشت به شبکه قدیمی-در حالی که-تأیید مجدد بازگشت شبکه به حافظه پنهان
کش TTL کارگر سرویس 30 روز 1 روز 10 دقیقه
حداکثر سن HTTP cache 30 روز 1 روز 10 دقیقه

سناریو: کش طولانی مدت (کش، بازگشت به شبکه)

  • هنگامی که یک منبع ذخیره شده در حافظه پنهان معتبر است (<= 30 روز): کارگر سرویس بلافاصله منبع ذخیره شده را بدون رفتن به شبکه برمی گرداند.
  • هنگامی که یک منبع ذخیره شده در حافظه پنهان منقضی می شود (بیش از 30 روز): کارگر سرویس برای واکشی منبع به شبکه می رود. مرورگر یک کپی از منبع در حافظه پنهان HTTP خود ندارد، بنابراین برای منبع سمت سرور می رود.

منفی: در این سناریو، حافظه پنهان HTTP ارزش کمتری را ارائه می دهد، زیرا مرورگر همیشه درخواست را به سمت سرور ارسال می کند که کش در سرویس کارگر منقضی شود.

سناریو: حافظه پنهان میان مدت (Stale-While-Revalidate)

  • هنگامی که یک منبع ذخیره شده معتبر است (<= 1 روز): کارگر سرویس بلافاصله منبع ذخیره شده را برمی گرداند و برای واکشی منبع به شبکه می رود. مرورگر یک کپی از منبع را در حافظه پنهان HTTP خود دارد، بنابراین آن کپی را به سرویس‌کار برمی‌گرداند.
  • هنگامی که یک منبع ذخیره شده منقضی می شود (> 1 روز): کارگر سرویس بلافاصله منبع ذخیره شده را برمی گرداند و برای واکشی منبع به شبکه می رود. مرورگر یک کپی از منبع در حافظه پنهان HTTP خود ندارد، بنابراین برای واکشی منبع به سمت سرور می رود.

منفی: کارگر سرویس برای لغو حافظه پنهان HTTP به منظور استفاده حداکثری از مرحله "تأیید مجدد"، به حذف حافظه پنهان اضافی نیاز دارد.

سناریو: کش کوتاه مدت (بازگشت شبکه به حافظه پنهان)

  • وقتی یک منبع ذخیره شده در حافظه پنهان معتبر است (<= 10 دقیقه): کارگر سرویس برای واکشی منبع به شبکه می رود. مرورگر یک کپی از منبع را در حافظه پنهان HTTP خود دارد، بنابراین آن را بدون رفتن به سمت سرور به کارمند سرویس برمی گرداند.
  • هنگامی که یک منبع ذخیره شده منقضی می شود (> 10 دقیقه): کارگر سرویس بلافاصله منبع ذخیره شده را برمی گرداند و برای واکشی منبع به شبکه می رود. مرورگر یک کپی از منبع در حافظه پنهان HTTP خود ندارد، بنابراین برای واکشی منبع به سمت سرور می رود.

منفی: مشابه سناریوی حافظه پنهان میان‌مدت، سرویس‌کار به منطق مخرب اضافی نیاز دارد تا کش HTTP را لغو کند تا آخرین منبع را از سمت سرور دریافت کند.

کارگر خدماتی در همه حالات

در تمام سناریوها، کش سرویس کارگر همچنان می‌تواند منابع ذخیره‌شده را در زمانی که شبکه ناپایدار است بازگرداند. از سوی دیگر، کش HTTP زمانی که شبکه ناپایدار یا قطع است قابل اعتماد نیست.

منطق انقضای کش مختلف در کش سرویس و لایه های HTTP

برای نشان دادن مزایا و معایب، ما دوباره به سناریوهای بلند مدت، میان مدت و کوتاه مدت نگاه خواهیم کرد.

سناریوها کش طولانی مدت کش میان مدت کش کوتاه مدت
استراتژی ذخیره سازی کارکنان خدمات کش، بازگشت به شبکه قدیمی-در حالی که-تأیید مجدد بازگشت شبکه به حافظه پنهان
کش TTL کارگر سرویس 90 روز 30 روز 1 روز
حداکثر سن HTTP cache 30 روز 1 روز 10 دقیقه

سناریو: کش طولانی مدت (کش، بازگشت به شبکه)

  • هنگامی که یک منبع ذخیره شده در حافظه پنهان سرویس دهنده معتبر است (<= 90 روز): کارگر سرویس بلافاصله منبع ذخیره شده را برمی گرداند.
  • هنگامی که یک منبع ذخیره شده در حافظه پنهان سرویس دهنده منقضی می شود (بیش از 90 روز): کارگر سرویس برای واکشی منبع به شبکه می رود. مرورگر یک کپی از منبع در حافظه پنهان HTTP خود ندارد، بنابراین به سمت سرور می رود.

مزایا و معایب:

  • حرفه ای: کاربران پاسخ فوری را تجربه می کنند زیرا کارگر سرویس منابع ذخیره شده را بلافاصله برمی گرداند.
  • طرفدار: سرویس‌کار کنترل دقیق‌تری در مورد زمان استفاده از حافظه پنهان و زمان درخواست نسخه‌های جدید منابع دارد.
  • منفی: یک استراتژی ذخیره سازی سرویس دهنده به خوبی تعریف شده مورد نیاز است.

سناریو: حافظه پنهان میان مدت (Stale-While-Revalidate)

  • هنگامی که یک منبع ذخیره شده در حافظه پنهان سرویس دهنده معتبر است (<= 30 روز): کارگر سرویس بلافاصله منبع ذخیره شده را برمی گرداند.
  • هنگامی که یک منبع ذخیره شده در حافظه پنهان سرویس دهنده منقضی می شود (بیش از 30 روز): کارگر سرویس برای منبع به شبکه می رود. مرورگر یک کپی از منبع در حافظه پنهان HTTP خود ندارد، بنابراین به سمت سرور می رود.

مزایا و معایب:

  • حرفه ای: کاربران پاسخ فوری را تجربه می کنند زیرا کارگر سرویس منابع ذخیره شده را بلافاصله برمی گرداند.
  • حرفه ای: کارمند سرویس می تواند اطمینان حاصل کند که درخواست بعدی برای یک URL معین از یک پاسخ تازه از شبکه استفاده می کند، به لطف اعتبارسنجی مجدد که "در پس زمینه" اتفاق می افتد.
  • منفی: یک استراتژی ذخیره سازی سرویس دهنده به خوبی تعریف شده مورد نیاز است.

سناریو: کش کوتاه مدت (بازگشت شبکه به حافظه پنهان)

  • هنگامی که یک منبع ذخیره شده در حافظه پنهان سرویس دهنده معتبر است (<= 1 روز): کارگر سرویس برای منبع به شبکه می رود. مرورگر منبع را از کش HTTP در صورت وجود آن برمی گرداند. اگر شبکه قطع باشد، سرویس‌کار منبع را از کش سرویس‌کار برمی‌گرداند
  • هنگامی که یک منبع ذخیره شده در حافظه پنهان سرویس دهنده منقضی می شود (> 1 روز): کارگر سرویس برای واکشی منبع به شبکه می رود. مرورگر منابع را از طریق شبکه واکشی می کند زیرا نسخه کش در حافظه پنهان HTTP منقضی شده است.

مزایا و معایب:

  • حرفه ای: هنگامی که شبکه ناپایدار یا خاموش است، سرویس دهنده منابع ذخیره شده را بلافاصله برمی گرداند.
  • منفی: کارگر سرویس برای لغو حافظه پنهان HTTP و درخواست‌های "اول شبکه" به حذف حافظه پنهان اضافی نیاز دارد.

نتیجه گیری

با توجه به پیچیدگی ترکیب سناریوهای حافظه پنهان، نمی توان یک قانون طراحی کرد که همه موارد را پوشش دهد. با این حال، بر اساس یافته‌های بخش‌های قبلی، چند پیشنهاد برای طراحی استراتژی‌های کش وجود دارد:

  • نیازی نیست که منطق کش کردن سرویس‌دهندگان با منطق انقضای ذخیره‌سازی HTTP سازگار باشد. در صورت امکان، از منطق انقضای طولانی‌تر در سرویس‌کار استفاده کنید تا کنترل بیشتری به کارگر خدمات بدهید.
  • کش HTTP هنوز نقش مهمی ایفا می کند، اما زمانی که شبکه ناپایدار یا قطع است قابل اعتماد نیست.
  • استراتژی‌های کش خود را برای هر منبع مجدداً بررسی کنید تا مطمئن شوید که استراتژی ذخیره‌سازی سرویس‌دهنده ارزش آن را بدون تضاد با حافظه پنهان HTTP فراهم می‌کند.

بیشتر بدانید