دانشنامهمقالات

Cache Control چیست

Cache Control چیست؟ کنترل کش یکی از ویژگی‌های مهم در وب است که نقش موثری در بهینه‌سازی عملکرد و سرعت بارگیری صفحات وب دارد.

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

در این راستا، Cache Control از سربرگ‌ها و هدرهای HTTP استفاده می‌کند تا دستورالعمل‌هایی را برای مرورگرها و سرورها دریافت کند.

Cache Control یک هدر حافظه پنهان HTTP است که شامل مجموعه‌ای از پارامترها برای تعریف رفتار کش مرورگر در درخواست‌های کاربر و پاسخ‌های سرور است.

تنظیمات Cache Control می‌تواند شامل دستورات مربوط به نگهداری حافظه کش مانند max-age و no-cache باشد. این دستورات به وب سایت‌ها اجازه می‌دهد که تعیین کنند چه منابعی قابل نگهداری در حافظه کش هستند و چه منابعی باید هر بار بازبینی شوند.

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

با استفاده از کنترل کش، می‌توان به بهبود سرعت بارگیری وبسایت، کاهش بارسرور و بهبود تجربه کاربران کمک کرد. در این مطلب، نحوه استفاده از Cache Control و تاثیر آن در بهبود عملکرد وبسایت‌ها را بررسی خواهیم کرد. همچنین، به توضیح مفاهیمی همچون کش مرورگر، هدرهای HTTP، هدرهای Cache Control و مزایای آن خواهیم پرداخت.

کش مرورگر چیست

کش مرورگر فرآیندی است که در آن یک مرورگر منابع وب سایت را ذخیره می‌کند تا آنها را در طول درخواست بعدی مشتری به سرعت بارگیری کند.

هنگامی که شخصی برای اولین بار از وب سایت شما بازدید می‌کند، مرورگر وب باید تک تک فایل‌ها را درخواست و دانلود کند تا صفحه موردنظر شما ارائه شود.

به عنوان مثال، وقتی یک صفحه از وب را با یک تصویر پس زمینه بارگیری کنید، تصویر در کش مرورگر شما ذخیره می‌شود. در بازدید بعد، متوجه می‌شوید که صفحه سریعتر بارگذاری می‌شود و تاخیر کاهش می‌یابد، زیرا مرورگر مجدد تصویر را از وب سرور درخواست نمی‌کند و از فایل‌های محلی بارگیری می‌کند.

به همین دلیل است که شما معمولاً «leverage browser caching» را به عنوان یک توصیه رایج در ابزارهایی مانند GTmetrix و Pingdom مشاهده می‌کنید.

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

به عنوان مثال، می‌توانید سرور خود را طوری پیکربندی کنید که فایل‌های JPEG را برای یک سال و فایل‌های PNG را فقط برای یک ماه ذخیره کند.

یک چارچوب زمانی مشخص وجود دارد که به عنوان Time to Live (TTL) شناخته می‌شود و پس از آن منبع ذخیره شده در فایل‌های محلی منقضی می‌شود.

اگر صفحه را پس از انقضای TTL بارگیری کنید، مرورگر باید درخواست دیگری را به وب سرور ارسال کند و یک نسخه جدید از منبع را دریافت کند. TTL برای هر مرورگر و سرور در هدرهای HTTP مشخص شده است.

اساسا، شما تاریخ انقضا را برای مدت زمانی که مرورگرهای بازدیدکنندگان باید محتوای خاصی را ذخیره کنند، تنظیم می‌کنید.

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

با تعیین تاریخ انقضا، می‌توانید اطمینان حاصل کنید که بازدیدکنندگان به‌طور دوره‌ای منابع مربوطه را دوباره دانلود می‌کنند تا از یک تجربه به‌روز اطمینان حاصل کنند.

آشنایی با هدرهای HTTP
آشنایی با هدرهای HTTP

هدرهای HTTP چیست

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

شبکه جهانی وب بر اساس پروتکل انتقال ابرمتن (Hypertext Transfer Protocol) عمل می‌کند که ترکیب تمام ارتباطات بین کلاینت‌ها و سرورها را مشخص می‌کند.

تعدادی هدر برای مشخص کردن انواع مختلف اطلاعات در ارتباطات مشتری و سرور وجود دارد.

برای درخواست‌ها، هدر معمولا حاوی اطلاعاتی در مورد منبع درخواست شده، مرورگر مشتری و فرمت‌های داده‌ای است که مشتری می‌پذیرد.

به طور کلی، هدرهای ذخیره HTTP را می‌توان به موارد زیر دسته بندی کرد.

  • General headers
  • Request headers
  • Response headers
  • Entity headers

هدرهای عمومی

General headers، اینها هدرهای ذخیره HTTP هستند که می‌توانند برای پیام‌های درخواست و پاسخ استفاده شوند، اما برای محتوای پیام اعمال نمی‌شوند.

Cache-Control یکی از این هدرها است. موارد دیگر عبارتند از Date که تاریخ و زمان پیام را مشخص می‌کند و Connection که مشخص می‌کند آیا اتصال شبکه پس از تراکنش باز می‌ماند یا خیر.

هدرهای درخواست

Request headers، هدرهایی هستند که در درخواست HTTP استفاده می‌شوند. آنها حاوی اطلاعات زیادی در مورد منبع دریافت شده یا در مورد درخواست مشتری هستند.

هدرهای پاسخ

Response headers، شامل اطلاعات اضافی در مورد پاسخ HTTP است. مثال‌ها عبارتند از Age، مدت زمانی را که شی در حافظه پنهان پراکسی بوده است و Location که نشان‌دهنده URL برای هدایت صفحه به آن است را مشخص می‌کند.

هدرهای موجودیت

برخلاف سایر هدرها، Entity headers حاوی اطلاعاتی در مورد محتوا و بدنه پیام هستند. آنها را می‌توان در درخواست‌های HTTP یا پیام‌های پاسخ HTTP استفاده کرد.

مثال‌ها عبارتند از Content-Length که اندازه موجودیت-بدنه را بر حسب بایت مشخص می‌کند و Content-Language که زبان در نظر گرفته شده برای مخاطب را توصیف می‌کند.

آشنایی با هدر Cache Control
آشنایی با هدر Cache Control

هدر Cache Control چیست

Cache-Control یک هدر HTTP است که برای کنترل کش کردن محتوا در HTTP استفاده می‌شود. این هدر کنترل می‌کند که برنامه‌ها و مرورگرها نحوه استفاده از کش محتوا را تنظیم کنند. با استفاده از این هدر، سرور می‌تواند دستورات کش را برای مرورگر و سرورهای واسط تعیین کند.

در واقع هدرهای کنترل کش، شامل اطلاعاتی در مورد هر عملی که باید با حافظه نهان انجام شود مانند نحوه ذخیره سازی، زمان ذخیره سازی و… می‌باشد.

آنها اساساً دستورالعمل‌هایی هستند که از جفت‌های کلید-مقدار جدا شده توسط دو نقطه تشکیل شده‌اند. “کلید” چیزی است که در سمت چپ کولون (:) ظاهر می‌شود و در این مورد همیشه کنترل کش است.

بیشتر بدانید : نصب و استفاده از ویرایشگر Vim در لینوکس سرور

مقدار هدر در سمت راست کولون ظاهر می‌شود. برای مثال، «Cache Control : max-age» یکی از این دستورالعمل‌ها است.

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

در ادامه، شما را با برخی از رایج‌ترین دستورالعمل‌های کنترل حافظه پنهان آشنا خواهیم کرد.

کنترل کش max-age

کنترل کش max-age یک شاخص در هدرهای HTTP است که زمان اعتبار کش را برای منابع در مرورگر تعیین می‌کند.

این شاخص به صورت ثانیه مشخص می‌شود و نشان می‌دهد که چقدر نسخه فعلی یک منبع معتبر است و در حافظه کش مرورگر نگهداری شود.

به عنوان مثال، max-age=90 به این معنی است که یک پاسخ HTTP قبل از اینکه بتواند برای استفاده مجدد در دسترس باشد، تا 90 ثانیه آینده به عنوان یک کپی ذخیره شده در مرورگر باقی می‌ماند.

اگر دسترسی مجددی به منبع در همان بازه زمانی انجام شود، مرورگر از حافظه کش استفاده می‌کند و به سرور درخواست مجددی ارسال نمی‌کند. کاربرد‌های کنترل کش max-age شامل کاهش زمان لود صفحات و کاهش بار سرور می‌شود.

S-Maxage

s-maxage شبیه دستورالعمل max-age است، اما “s” مخفف shared as در حافظه پنهان مشترک است. این مربوط به شبکه‌های تحویل محتوا (CDN) و سایر حافظه های پنهان واسطه است. این دستورالعمل max-age را لغو می‌کند و در صورت وجود فیلد سرصفحه منقضی می‌شود.

کش کنترل no-cache

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

ETag یکی دیگر از هدرهای HTTP است که حاوی یک نشانه منحصر به فرد برای نسخه منبع در زمان درخواست آن است. هر زمان که منبع به روز شود، این نشانه در سرور مبدا تغییر می‌کند.

وقتی کاربر به صفحه‌ای با منبع «بدون کش» باز می‌گردد، کاربر همیشه باید به سرور مبدا متصل شود و ETag موجود در منبع ذخیره‌شده را با یک منبع در سرور مقایسه کند.

اگر ETag ها یکسان باشند، منبع ذخیره شده در حافظه پنهان در اختیار کاربر قرار می گیرد. اگر نه، به این معنی است که منبع به روز شده است و مشتری باید یک نسخه جدید را دانلود کند تا در اختیار کاربر قرار دهد.

این فرآیند تضمین می‌کند که کاربر همیشه به روزترین نسخه آن منبع را بدون نیاز به دانلودهای غیر ضروری دریافت می‌کند.

آشنایی با کش کنترل no-store
آشنایی با کش کنترل no-store

کش کنترل no-store

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

no-transform

هنگامی که منابع در سرور کش ذخیره می‌شوند، گاهی اوقات پروکسی‌های میانی می‌توانند تغییراتی در این دارایی‌ها ایجاد کنند.

به عنوان مثال، آنها می‌توانند فرمت تصاویر و فایل‌ها را به منظور صرفه جویی در فضا و بهبود عملکرد تغییر دهند. اگر قرار باشد دارایی با نهاد اصلی یکسان بماند، این امر می‌تواند مشکلاتی ایجاد کند.

همچنین نمی‌توانند بدنه پاسخ Content-Encoding، Content-Range یا Content-Type را ویرایش کنند.

Public Cache-Control

کنترل کش عمومی، به این معنی است که منبع را می‌توان توسط هر واسطه‌ای بین سرور و کلاینت، مانند CDN و سرور پروکسی، کش کرد.

Private Cache-Control

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

این‌ها اغلب منابع حاوی داده‌های خصوصی هستند، مانند وب سایتی که اطلاعات شخصی کاربر را نمایش می‌دهد.

CDN Cache Control چیست

CDNها از تکنیک‌های مختلفی برای سرعت بخشیدن به تحویل محتوا مانند تصاویر و سایر فایل‌های رسانه‌ای روی سرورهای نزدیک به محل اصلی کاربر نهایی استفاده می‌کنند.

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

در یک شبکه تحویل محتوا (CDN)، زمانی که کاربر درخواستی را ارسال می‌کند، CDN بررسی می‌کند که آیا آخرین نسخه از منبع ذخیره شده در حافظه کش خود را دارد یا خیر. اگر این کار را کرد، به جای درخواست آن از سرور اصلی، کپی ذخیره شده را به مشتری برمی‌گرداند.

CDN از هدرهای کنترل کش استفاده می‌کند تا مشخص کند که یک منبع باید چه مدت در حافظه پنهان ذخیره شود و اینکه آیا باید قبل از استفاده مجدداً اعتبارسنجی شود یا خیر.

به عنوان مثال، هدر Cache-Control را می‌توان برای تعیین اینکه یک منبع باید برای مدت زمان مشخصی کش شود یا اینکه اصلاً نباید کش شود، استفاده می‌شود.

ابر آسیاتک با ارائه CDN رایگان، علاوه بر افزایش امنیت سایت مشترکین، به افزایش سرعت بارگذاری و نمایش صفحات وب کمک کرده و با پخش صحیح درخواست کاربران بر روی چندین سرور، ترافیک وبسایت‌ها را چندین برابر می‌نماید.

مزایای Cache Control چیست

Cache-Control یک هدر استاندارد در HTTP است که نقش مهمی در بهینه‌سازی و سرعت بخشیدن به فرآیند تحویل محتوا به کاربر دارد. اهمیت Cache-Control به دلیل موارد زیر است:

بهینه‌سازی مصرف پهنای باند

با استفاده از Cache-Control، سرور می‌تواند نوع محتواها و زمان به‌روزرسانی آنها را مجدداً تعیین کند. این کار موجب کاهش تعداد درخواست‌ها به سرور و در نتیجه، کاهش مصرف پهنای باند می‌شود.

سرعت بخشیدن به لود صفحه

مرورگر می‌تواند محتواها را از حافظه پنهان خود بارگیری کند و نیازی به ارسال درخواست به سرور نداشته باشد. این کار باعث سرعت بخشیدن به لود صفحه و بهبود تجربه کاربر می‌شود.

کاهش بار سرور

سرور می‌تواند کش‌هایی از محتواها ایجاد کند و نیازی به ایجاد محتوای تکراری نداشته باشد. این کار باعث کاهش بار بر سرور و هزینه‌های سرویس دهی می‌شود.

بهینه‌سازی عملکرد و سرعت وبسایت

استفاده صحیح از Cache-Control می‌تواند به سرعت بارگیری صفحات وب کمک کند. با استفاده از دستورات مانند max-age و must-revalidate می‌توان نشان داد که یک منبع می‌تواند در حافظه نگهداری شود و یا باید پنجره زمانی برای بارگیری مجدد تعیین شود. این کش سازی منجر به کاهش هزینه بارگیری منابع تکراری و حجم داده‌های ارسالی شده بین مرورگر و سرور می‌شود.

مدیریت داده‌های مخابره شده

Cache Control به سرور اجازه می‌دهد تا کنترل داشته باشد که آیا مرورگر باید یک منبع را در حافظه نگهداری کند و یا همواره به سرور برای بارگیری مجدد درخواست کند. این کنترل به کاربر امکان می‌دهد تا از محافظت خود در برابر تغییرات نامطلوب در منابع فعلی و اطمینان از دریافت آخرین نسخه‌ها استفاده کند.

جمع بندی

امروزه، با توسعه روزافزون استفاده از اینترنت و وبسایت‌ها، بهینه‌سازی عملکرد و سرعت بارگذاری صفحات وب امری بسیار مهم و حیاتی شده است. یکی از مکانیسم‌های مورد استفاده برای بهبود عملکرد وبسایت‌ها و کاهش زمان بارگذاری صفحات، استفاده از Cache Control است. کش کنترل ابزاری است که در پروتکل HTTP استفاده می‌شود و به وب سرور‌ها امکان می‌دهد که کش داده‌ها را کنترل کنند. با استفاده از Cache Control، وب سرور برخی از داده‌ها را در کش ذخیره می‌کند تا درخواست‌های آینده را بدون بارگذاری دوباره از منبع اصلی اطلاعات به‌صورت سریعتر پاسخ دهد.

[yasr_overall_rating]

نوشته های مشابه

دیدگاهتان را بنویسید

نشانی ایمیل شما منتشر نخواهد شد. بخش‌های موردنیاز علامت‌گذاری شده‌اند *

همچنین ببینید
بستن
دکمه بازگشت به بالا