Cache-Control چیست و چگونه آن را مدیریت کنیم؟
در این مقاله میخوانید
Cache-Control چیست؟ برای پاسخ به این سوال، فرض کنید همیشه به یک رستوران میروید و هربار فقط یک نوع غذا سفارش میدهید. به محض ورودتان به رستوران، مستقیماً سراغ میز و صندلی میروید که محل مخصوص شما برای نشستن است. وقتی برای دریافت سفارش نزد شما میآیند، بهجای جستجو در منو و انتخاب بین غذاهای مختلف میگویید: «همان همیشگی». در این رستوران، محل نشستن شما و نوع غذایی که هربار سفارش میدهید، در حافظه کارکنان رستوران باقی مانده است؛ درنتیجه نیازی نیست مدام زحمت انتخاب غذا از منوی متنوع رستوران یا پیدا کردن میز غذا را به خود بدهید.
هدر Cache Control نیز نقشی مانند کارکنان رستوران دارد که با ذخیره کش مرورگر شما، بازدید از سایت را برایتان راحتتر و سریعتر میکند. در این مقاله از بلاگ پارس پک، بهطور کامل هدر Cache Control و نحوه استفاده از Cache-Control را در وبسرورهای آپاچی و Nginx بررسی خواهیم کرد.
منظور از Cache-Control چیست؟
کنترل کش (Cache-Control) نوعی هدر HTTP است که مطابق با رفتار کش مرورگر کاربر عمل میکند. این یعنی زمانی که از سایتی بازدید میکنید، مرورگر منابعی مثل تصویر لوگو و بنرهای یک سایت را در حافظه کش خود پنهان میکند؛ درنتیجه اگر مجدداً صفحه را بارگذاری کنید، صفحه برایتان سریعتر لود خواهد شد.
منظور از هدرهای HTTP در تعریف کنترل کش، نوعی راه ارتباطی است بین درخواستهایی که کاربر به سرور و پاسخهایی که سرور به کاربر ارسال میکند. هدرهای HTTP تعیین میکند که اطلاعات درخواستی از چه منبعی است، کاربر از چه مرورگری استفاده میکند و چه فرمت دادهای را میپذیرد.
در پاسخ به اینکه کنترل کش چیست، باید گفت وقتی کاربر مجدداً از سایتی بازدید میکند، کنترل کش قوانینی را تعریف خواهد کرد که طی هر درخواست کاربر، تعیین میکند اطلاعات از کش مرورگر کاربر بارگذاری شود یا مرورگر درخواست جدید به سرور ارسال کند. در ادامه، برای درک بهتر اجازه دهید نگاهی به کش مرورگر بیندازیم.
کش مرورگر چیست؟
زمانی که سایتی را با مرورگر خود جستجو میکنید، کش مرورگر (Browser Cache) اطلاعات آن سایت را بهعنوان منبع ذخیره میکند. سپس اگر مجدداً به سایت موردنظر برگردید، اطلاعات سایت، سریعتر برایتان بارگذاری میشود. این کار، هنر کش مرورگر است.
هر مرورگر برای ذخیره اطلاعات در حافظه پنهان خود، یک مقدار TTL یا Time To Live دارد. مقدار TTL زمان انقضای یک کش است. اگر پس از انقضای TTL، کاربر از سایت بازدید کند، مرورگر درخواست خود را به سرور ارسال کرده و این بار بهجای حافظه کش، اطلاعات بهطور مستقیم از سرور بارگذاری خواهد شد.
برای فعالسازی Browser Cache، ابتدا باید بررسی کنید چه مدتزمانی قصد دارید اطلاعاتی مانند فایلهای سایت، تصاویر یا محتواهای دیگر در مرورگر بهصورت کش باقی بماند. شما میتواند از طریق افزونه یا بهصورت دستی هدرهای کنترل کش مرورگر را تنظیم کنید. برای آشنایی بیشتر با تنظیمات کش مرورگر، خواندن مقاله «تنظیمات Caching در کلودفلر برای افزایش عملکرد وبسایت» کمکتان خواهد کرد.
برای آشنایی با اهمیت استفاده از کش وبسایت و نحوه فعالسازی آن برای وبسایتهای وردپرسی مقاله زیر را بخوانید.
کش CDN چیست؟
به کش یا حافظه پنهانی که توسط CDN مورد استفاده قرار میگیرد، کش CDN میگویند. وقتی مرورگر درخواستی را از سایتی که مجهز به CDN است، ارسال میکند، درخواست مرورگر به جای سرور اصلی به CDN فرستاده میشود. اگر CDN، نسخه کش شده از سایت موردنظر را داشته باشد، آن را به مرورگر تحویل میدهد؛ درنتیجه میزان استفاده از پهنای باند و زمان بارگذاری سایت تا حد قابل توجهی کاهش پیدا میکند. زیرا دیگر نیازی نیست از زمان درخواست مرورگر تا سرور اصلی تمام مسیر را طی کند. بههمین دلیل، سایتهایی که مجهز به کش CDN هستند، لود و بارگذاری سریعتری دارند.
هر آنچه باید درباره مزایا و قابلیتهای شبکه توزیع محتوا بدانید را در مقاله زیر بخوانید.
اهمیت Cache-Control چیست؟
حفظ و نگهداری از کش مرورگر کاربر، یک راهکار کاربردی و مؤثر برای بهبود تجربه کاربری و افزایش سرعت سایت است. اما این راهکار بدون استفاده از کش کنترل مؤثر نخواهد بود. بدون استفاده از Cache Control منابع و محتوا فارغ از درنظر گرفتن ماهیت خود در حافظه پنهان کش میشود؛ درنتیجه ممکن است اطلاعات حساسی مثل اطلاعات بانکی یا محتوایی که نیاز است بهطور مداوم بهروزرسانی شود، در حافظه کش باقی بماند.
به بیان سادهتر، کاربرد Cache Control در تعریف ماهیت محتوا است. هدر Cache Control هر نوع کش از جمله کش مرورگر را کارآمدتر کرده است. سایتهایی که از CDN کلودفلر استفاده میکنند، با استفاده از هدر Cache Control کشینگ را به بهترین نحو ممکن انجام داده و عملکرد بهتری دارند.
کلودفلر چیست و چه مزایا و معایبی دارد؟ نحوه استفاده از کلودفلر چگونه است؟ در مقاله زیر بخوانید.
پارامترهایی که در Cache-Control وجود دارد
در پاسخ به این سوال که پارامترهای هدر کنترل کش چیست، میتوان گفت هدرهای کنترل کش از جفت Key-Valueهایی تشکیل شده است که توسط «:» از هم جدا میشوند. عبارتی که همیشه در سمت چپ «:»، قرار دارد، همان key کش کنترل است. عبارت سمت راست «:» نیز مقدار یا Value بوده که معمولاً با یک یا چند «,» از هم جدا میشوند. این عبارات، دستورالعملهایی هستند که وبسرورهای HTTP به مرورگر ارسال و تعیین میکند چه منبعی در حافظه کش به چه مدتزمان باقی بماند. در ادامه مقاله «Cache-Control چیست» با این نوع دستورالعملها بیشتر آشنا خواهید شد.
۱. Cache-Control: Private
منظور از Private در Cache-Control چیست؟ این دستورالعمل نشان میدهد که محتوا در هیچ پروکسی کش نشود. این یعنی محتوا فقط توسط کاربر (یا همان کلاینت) قابل کش شدن است و CDN یا پروکسی نمیتواند آن را کش کند. پلتفرمهایی مثل اینستاگرام که امکان پرایوت کردن پیج را دارند، از این دستورالعمل استفاده میکنند. بهطوریکه اطلاعاتی که کاربر از پیج خود میبیند با اطلاعاتی که سایر افراد از پیج پرایوت او مشاهده میکنند، متفاوت است.
این دستورالعمل که اغلب مناسب وبسایتهایی با اطلاعات شخصی است، روشی برای تأمین امنیت دادههای یک سایت محسوب نمیشود و همچنان نیاز است از گواهی SSL استفاده کنید.
۲. Cache-Control: Public
این دستورالعمل برخلاف عبارت بالا، نشان میدهد که منبع یا سایت میتواند توسط هر نوع کش ذخیره شود. این یعنی علاوهبر مرورگر کاربر، پروکسی و CDN نیز میتواند محتوا را کش کند.
۳. Cache-Control: No-Store
منظور از دستورالعمل No Store در Cache-Control چیست؟ این دستور نشان میدهد که سایت یا محتوا توسط هیچ نوع کش از جمله کش مرورگر کاربر، پروکسی و CDN ذخیره نخواهد شد؛ درنتیجه طی هر بار درخواست کاربر برای دریافت محتوا، درخواست او از مرورگر به سرور ارسال شده و مستقیماً از سرور بارگذاری خواهد شد. این پارامتر برای دادههای حساسی مثل اطلاعات بانکی مناسب است. اگر نمیخواهید هیچ محتوایی در کش ذخیره شود، از این دستور استفاده کنید.
۴. Cache-Control: No-Cache
دستورالعمل No-Cache نشان میدهد کش وبسایت قابل نگهداری است اما محتوای آن باید قبل از ارائه به کاربر، اعتبارسنجی (Re-Validate) شود. این یعنی محتوا پس از درخواست کاربر، بهکمک ETagها برای تأیید اعتبار به سمت سرور ارسال میشود. سرور پس از تأیید (نه دانلود و بارگذاری مجدد) محتوا را به کاربر نشان خواهد داد.
نقش ETagها در Cache-Control چیست؟ هدرهای ETag نوعی هدر HTTP هستند که نسخهای از محتوا را در زمان درخواست نشان میدهند. هر زمان محتوا یا منبع بهروز شود، نسخه ETag نیز تغییر خواهد کرد. طی هر درخواست کاربر با دستورالعمل No-Cache، مرورگر به سرور متصل شده و ETag محتوای ذخیره شده در سرور را با ETag کش شده مقایسه میکند.
اگر ETagها مشابه باشند (StrongValidating ETag)، مرورگر با خیال راحت نسخه کش شده را به کاربر نشان میدهد. درصورتیکه ETag مرورگر با سرور متفاوت باشد (Weak ETag) سرور مجدداً اطلاعات منبع یا سایت را دانلود و بارگذاری میکند. با این دستورالعمل، همیشه اطمینان خواهید داشت که کاربر بهروزترین محتوا را دریافت خواهد کرد.
۵. Cache-CControl: Max-Age
این دستورالعمل حداکثر زمان ماندگاری کش را برحسب ثانیه نشان میدهد. برای مثال، دستورالعمل زیر را درنظر بگیرید:
Cache-Control: max-age=3600, public
نمونه بالا یعنی محتوا بهصورت public (توسط هر نوع کش) به مدت ۳۶۰۰ ثانیه یا یک ساعت، بهصورت کش باقی میماند. پس از این بازه زمانی، اگر کاربر درخواست جدیدی ارسال کند، نسخه جدید محتوا از سمت سرور اصلی مجدداً دانلود و بهروزرسانی میشود.
۶. S-Maxage: Seconds
دستورالعمل بالا، در استفاده از کش کنترل برای کشهای مشترک مانند CDNها تعریف شده است. S-Max تعداد ثانیههایی را نشان میدهد که یک کش اشتراکی قابلیت ذخیره کردن دارد.
۷. Expires
تا چند سال پیش، دستور Expires دستور اصلی برای تعیین انقضای کش براساس تاریخ هفته، ماه و ساعت بود. امروزه در اغلب سیستمهای مدرن، Max-Age و S-Maxage برای تعیین انقضای کش کاربرد دارند و جای این دستور را گرفتند.
۸. Must-Revalidate
معنای Must-Revalidate در Cache-Control چیست؟ این دستورالعمل نشان میدهد که محتوا را میتوان در حافظه پنهان ذخیره کرد و در حالت بهروزرسانی مجدداً از آن استفاده کرد. درواقع، اگر محتوا قدیمی شود، قبل از استفاده مجدد نیاز است توسط سرور تأیید شود.
زمانی که سرور قطع میشود، HTTP به کشها اجازه میدهد تا نسخه قدیمی محتوا را به نمایش بگذارند. دستورالعمل Must-Revalidate راهی برای جلوگیری از این اتفاق است. با استفاده از این دستور و درصورت تأیید سرور، محتوای قدیمی به نمایش درمیآید.
نکته:
وقتی برای اولین بار از سایتی بازدید میکنید، اطلاعات سایت در کش مرورگر شما ذخیره شده تا درصورت بازدید مجدد، محتوای سایت برایتان سریعتر بارگذاری شود. طی هر درخواست بارگذاری محتوای یک سایت از مرورگر به سمت سرور، هدر کش کنترل، تعیین میکند محتوای موردنظر از حافظه کش یا از سرور ارسال شود. بارگذاری محتوا از حافظه کش، سرعت بارگذاری صفحات سایت را بالا برده و تجربه کاربری بهتری برای کاربران رقم خواهد زد.
۹. Proxy-Revalidate
این دستورالعمل نیز مانند دستورالعمل Must-Revalidate عمل میکند. با این تفاوت که فقط برای کش مشترک پروکسی مورد استفاده قرار میگیرد. استفاده از این دستور زمانی کاربردی خواهد بود که برای احراز هویت کاربران یک سایت با ترافیک بالا از پروکسی استفاده شود. بهاینترتیب، هربار که کاربر درخواستی برای احراز هویت ارسال میکند، بهکمک دستورالعمل Proxy-Revalidate، اطلاعات او در حافظه کش پروکسی ذخیره شده و برای درخواست احراز هویت مجدد، کاربر نیازی به احراز هویت نخواهد داشت.
۱۰. No-Transform
برخی از واسطهها بهطور خودکار، محتوا را تغییر میدهند. برای مثال، حجم برخی از تصاویر را کاهش میدهند. دراینصورت، محتوا برای کاربر بهدرستی ظاهر نمیشود. دستورالعمل No-Transform نشان میدهد که واسطهها فارغ از کش شدن یا نشدن محتوا، نباید آن را تغییر دهند.
۱۱. Last-Modified
این دستورالعمل، زمان آخرین تغییرات یک سند را نشان میدهد. زمانی که یک Cache Stores، با دستورالعمل Last modified شناخته میشود، یعنی کش از آخرین زمانی که بارگذاری شده، تغییر پیدا کرده است. استفاده از این دستور نیز نوعی اعتبارسنجی کش است و نشان میدهد آیا کش از آخرین بارگذاری، تغییر کرده است یا خیر.
۱۲. Stale-While-Revalidate
این دستور نشان میدهد کش همزمان که دنبال محتوای تازه است، محتوای قدیمی را نیز میتواند به کاربر نشان دهد. برای مثال، دستورالعمل زیر را درنظر بگیرید:
Cache-Control: max-age=۶۰۴۸۰۰, stale-while-revalidate=۸۶۴۰۰
در مثال بالا، محتوا به مدت ۶۰۴۸۰۰ ثانیه یعنی ۷ روز تازه است و پس از ۷ روز منقضی میشود. کش مجاز است از آن برای هر درخواستی که در ۲۴ ساعت بعد انجام میشود، استفاده کند؛ به شرط آنکه اعتبارسنجی آن از سمت سرور انجام شود.
۱۳. Stale-If-Error
دستورالعمل بالا نشان میدهد تا زمانی که سرور با خطا روبهرو است، کش میتواند محتوای قدیمی را به کاربر نشان دهد. منظور از خطای سرور هر وضعیتی از سرور است که منجر به بروز خطای ۵۰۰، ۵۰۲، ۵۰۳ یا ۵۰۴ شود.
۱۴. Immutable
معنای Immutable در Cache-Control چیست؟ این دستورالعمل نشانگر ثابت ماندن محتوای کش شده است. بهترین راهکار برای کش کردن محتوای ثابت یا URLهای بدون تغییر، استفاده از این دستورالعمل است. زمانی که کاربر، مرورگر را بارگذاری میکند، مرورگر درخواست مشروط خود را برای اعتبارسنجی به سرور ارسال میکند. دستورالعمل Immutable، نشان میدهد باوجودیکه محتوا جدید بوده، تغییرناپذیر است. بهاینترتیب، از درخواست شرطی و اعتبارسنجی غیرضروری به سرور جلوگیری میکند.
باوجودیکه دستورالعملهای هدر کنترل کش به حروف بزرگ و کوچک حساس نیستند، اما بهتر است از حروف کوچک استفاده کنید. زیرا در برخی موارد، دستورالعملهایی با حروف بزرگ قابل اجرا نخواهد بود. همچنین دستورات مختلف را میتوانید با علامت «,» از هم جدا کنید.
برای آشنایی با آموزش صفر تا صد مدیریت نیمسرورها در Cloudflare مقاله زیر را از دست ندهید.
استفاده از Cache Control در وب سرورهای مختلف
در استفاده از Cache Control، نیاز است دستورالعمل هدرهای مربوط به محتوا را ارسال کنیم. اساس کار، استفاده از فایل htaccess. است. مثال زیر را درنظر بگیرید:
Header set Cache-Control "max-age=2628000, public"
مشکلی که کد بالا دارد، این است که هرچیزی را کش میکند. این یعنی توانایی کش کردن فایلهای مختلف را بهصورت جداگانه ندارد. برای کش کردن فایلهای مختلف، ما از دستور زیر استفاده میکنیم:
# One month for most static assets <filesMatch ".(css|jpg|jpeg|png|gif|js|ico)$"> Header set Cache-Control "max-age=2628000, public" </filesMatch>
این کد میگوید اگر فایل موردنظر یکی از فایلهای (CSS، jpg، jpeg یا png) بود، آنگاه هدر کنترل کش، دستور زیر را اعمال کند:
Header set Cache-Control "max-age=2628000, public
بهترین راه در استفاده از کش کنترل این است باتوجه به نوع وبسرور خود نوع هدر Cache Control را تعیین کنید. در ادامه، نحوه پیکربندی هدر Cache Control در وبسرور آپاچی و NGINX را بررسی خواهیم کرد.
نحوه پیکربندی هدرهای Cache-Control در آپاچی
درصورتیکه از وبسرور آپاچی استفاده میکنید، میتوانید با اضافه کردن دستورالعمل «fileMatch» در هدر Cache Control استراتژی مختلف کش وبسایت را برای فایلهای مختلف بهکار بگیرید. برای مثال، میتوانید کد زیر را در فایل http.conf قرار دهید. البته دسترسی شما به فایل کانفیگ بستگی به شرکت هاستینگ دارد. اگر امکان دسترسی به فایل http.conf را ندارید، کافیاست دستور موردنظر را در فایل htaccess. قرار دهید:
One year for image files # <filesMatch ".(jpg|jpeg|png|gif|ico)$"> Public 31536000 Header set Cache-Control "max-age= </filesMatch> # One month for css and js <filesMatch ".(css|js)$"> , public 2628000 " Header set Cache-Control "max-age= </filesMatch>
در این دستور، همانطور که میبینید، با استفاده از filesMatch، به مدت یک سال فایل تصاویر و به مدت یک ماه فایل css و js را با دستورالعمل هدر کش کنترل، ذخیره کردیم. همچنین، برای ذخیره محتوای Static به مدت یکسال، میتوانید کد زیر را در فایل htaccess. قرار دهید.
Cache everything for an year Header set Cache-Control "max-age=31536000, public"
نحوه پیکربندی هدرهای Cache-Control در NGINX
شیوه پیکربندی NGINX برای Cache-Control چیست؟ برای فعال کردن دستورالعمل Cache-Control در Nginx، دو دستورالعمل اصلی در اختیار دارید:
- Proxy_Cache_Path
- Proxy_Cache
دستورالعمل Proxy_Cache_Path مسیر و پیکربندی حافظه پنهان را تعیین کرده و Proxy_Cache آن را فعال میکند. برای درک بهتر، دستور زیر را درنظر بگیرید:
proxy_cache_path /path/to/cache levels=1:2 keys_zone=my_cache:10m max_size=10g inactive=60m use_temp_path=off; server { # ... location / { proxy_cache my_cache; proxy_pass http://my_upstream; } }
در ادامه، هریک از پارامترهایی که در دستور بالا وجود دارد، بررسی خواهیم کرد:
۱. /Path/To/Cache
مسیر دایرکتوری حافظه محلی برای کش کردن است.
۲. Levels
یک مسیر دوسطحی را در دایرکتوری حافظه تعریف میکند. از آنجایی که داشتن تعداد زیاد فایل در یک دایرکتوری ممکن است سرعت دسترسی به فایل را کمتر کند، این دستور، یک دایرکتوری دو سطحی برای نگهداری فایلها تعریف میکند؛ درنتیجه اگر فایلی باقی ماند، به سطح levels در Nginx منتقل خواهد شد.
۳. Keys_Zone
Keys_Zone هدر Cache Control در Nginx، محلی بهعنوان حافظه مشترک برای ذخیره کش و متادیتا مانند زمان استفاده است. داشتن یک کپی از Key_Zone در حافظه باعث میشود تا Nginx، بدون نیاز به بررسی حافظه، سریعاً یک درخواست HIT یا MISS تشخیص دهد. این دستور، سرعت بررسی و تشخیص Nginx را افزایش میدهد.
منظور از Cache Hit درخواستی است که مرورگر برای دریافت محتوا از حافظه کش ارسال کرده و Cache Miss، درخواستی است که مرورگر به سرور اصلی فرستاده و بعد از دریافت پاسخ، محتوا را کش میکند.
۴. Max_Size
این پارامتر در هدر Cache Control در Nginx، حداکثر اندازه کش را تعیین میکند. در مثال بالا، حداکثر کش ما، ۱۰ گیگابایت است. این پارامتر اختیاری بوده و با تعیین نکردن مقدار حافظه کش، امکان استفاده از تمام فضای موجود در دیسک را خواهید داشت.
۵. Inactive
پارامتر Inactive در هدر Cache Control وبسرور Nginx تعیین میکند یک فایل چه مدت در حافظه پنهان بدون دسترسی باقی خواهد ماند. در مثال بالا، تعیین Inactive=60m میگوید اگر فایلی تا ۶۰ دقیقه بدون درخواست باقی بماند، فارغ از اینکه زمان انقضای کش آن رسیده است یا خیر، از حافظه کش پاک شود. مقدار پیشفرض Inactive، مدت ۱۰ دقیقه است.
NGINX ابتدا فایلهایی که برای کش درنظر گرفته است، در یک مکان ذخیره موقت تعریف کرده و سپس با دستور Use_Temp_Path=off، تعیین میکند که فایلها در دایرکتوری کش قرار گیرند. در استفاده از Cache-Control برای وبسرور Nginx، نوع متفاوتی از دستورات را مینویسیم.
برای مثال، برای تعیین مدت زمان ماندگاری یا انقضا بهجای بهکار بردن Max-Age از دستورالعمل Expires استفاده میکنیم. به مثال زیر توجه کنید:
location ~* \.(jpg|jpeg|png|gif|ico|css|js)$ { expires 365d; }
در دستور بالا پس از Location، آدرس مسیری که قصد کش کردن آن را داریم، قرار دادیم. آیکون«~*» به معنای تمام مسیرها و پوشهها است. سپس نوع فایلهای موردنظر برای کش را تعریف کردیم. دستور Expires نیز مدت زمان انقضای کش را مشخص میکند. شما میتوانید با استفاده از پارامترهای هدر Cache Control، دستور کاملتری تعریف کنید. برای مثال:
location ~* \.(js|css|png|jpg|jpeg|gif|ico)$ { expires 2d; add_header Cache-Control "public, no-transform"; }
در مثال بالا، با استفاده از دستور “Header Cache-Control “public، حالت عمومی را برای کش انتخاب کردیم. این یعنی محتوا میتواند توسط هر نوع کش ذخیره شود. برای نوشتن دستورالعملهای پیچیدهتر، میتوانید به وبسایت رسمی Nginx مراجعه کنید.
کاربرد Cache Control در CDN
حافظه کش را میتوان مانند یک درایو لوکال برای سرور درنظر گرفت که موجب میشود دسترسی و انتقال اطلاعات سریعتر انجام شود. همین موضوع برای CDNها نیز صدق میکنند. CDNها برای توزیع سریع محتوا و مصرف بهینه پهنای باند، اطلاعات را به سرورهای پروکسی منتقل میکند. بهطورکلی، از مزیت و کاربرد Cache Control در CDN میتوان به موارد زیر اشاره کرد:
۱. استفاده از کش کنترل، مدیریت کش را سادهتر میکند
تگ کردن دستی هر فایل، تغییر دادن کد و مدیریت هدرهای مختلف کش، کار توسعهدهندگان وب را سختتر میکند. CDN با امکان مدیریت کش در داشبورد کاربرپسند خود این امکان را به مدیران داده تا درصورت دلخواه دستورالعملهای هدر Cache Control را تغییر داده یا برای برخی از فایلها غیرفعال کنید.
۲. با کمک الگوریتم یادگیری ماشین، فرایند کش را بهطور خودکار تنظیم میکند
در برخی از CDNهای پیشرفته، شما میتوانید هدر Cache Control را بااستفاده از الگوریتمهای خودکار یادگیری ماشین تعریف کنید؛ درنتیجه محتوا سریعتر قابل تشخیص خواهند بود. برای مثال، یک فایل HTML را که در دراز مدت تغییری نکرده است، بهعنوان تگ استاتیک میتوان کش کرد تا صفحه سریعتر بارگذاری شود. الگوریتم یادگیری ماشین با بررسی وضعیت صفحه، به محض اینکه تغییری در آن ایجاد شود، آن را در دسته محتوای داینامیک طبقهبندی میکند. این سیاست باعث میشود تا فرایند کشینگ بهینه و سرعت دریافت محتوا سریعتر شود.
۳. بهکمک سرورهای پروکسی، حافظ کش مرورگر را افزایش میدهد
مرورگر پس از اولین بازدید شما از سایت، بهطور خودکار، فرایند کش کردن صفحات سایت را آغاز میکند. CDN با کمک سرورهای پروکسی و استفاده از کش کنترل سرعت بارگذاری صفحات را افزایش میدهد. با این کار، این اطمینان را به کاربر میدهد باتوجه به موقعیت جغرافیایی که کاربر قرار دارد، از نزدیکترین سرور، کپی از سایت را به او نمایش خواهد داد. مانند زمانی که قصد دارید بهطور آنلاین از اسنپ مارکت خرید کنید و اسنپ نزدیکترین فروشگاهها را به شما نشان میدهد.
برای آشنایی با نحوه انجام تنظیمات کشینگ در کلودفلر به زبان ساده مقاله زیر را بخوانید.
جمعبندی
Cache-Control چیست؟ پاسخ این سوال را بهطور کامل در این مقاله بررسی کردیم. هدر Cache Control نوعی هدر HTTP است که مطابق با رفتار کش مرورگر کاربر عمل کرده و شما میتوانید به کمک آن کنترل دقیقتری روی کش سایت خود داشته باشید. همچنین نحوه استفاده از Cache Control را در وبسرورهای آپاچی و Nginx بررسی کردیم. امیدواریم این مقاله به شما در استفاده از کش کنترل، پیکربندی و شناخت مفهوم آن کمک کرده باشد. درصورتیکه در این زمینه نیاز به راهنمایی بیشتر دارید، سوالاتتان را میتوانید در انتهای همین مقاله بنویسید تا کارشناسان پارس پک راهنماییتان کنند.
توجه کنید!
مهندسان و متخصصان پارس پک با CDN حرفهای امکان استفاده از Cache Control و اجرای راحت Caching را فراهم کردهاند. استفاده از CDN با کاهش فاصله بین سرور و کاربر باعث افزایش سرعت بارگذاری وبسایت شما شده و همزمان استفاده از پهنای باند کم میشود، ئس علاوه بر جلب رضایت مخاطب، هزینههایتان را نیز کاهش میدهید. حتی با استفاده از پلن رایگان CDN پارس پک میتوانید با ترافیک و درخواستهای نامحدود داخلی و خارجی، از یک Caching حرفهای بهرهمند شوید.
سؤالات متداول
۱. Cache-Control چیست؟
هدر Cache Control یک هدر HTTP برای کنترل، مدیریت و درخواست کش مرورگر به سرور است. با پارامترهای مختلف از جمله تعیین حداکثر زمان انقضا و ماندگاری هدر کنترل کش میتوانید مدیریت دقیقی روی کش داشته باشید.
۲. چرا استفاده از کش کنترل اهمیت دارد؟
هدر کنترل کش وبسایت موجب عملکرد بهینه سایت شده و پهنای باند و حجم دیتای بین سرور و مرورگر کاربر را کاهش میدهد.
۳. Max-Age در Cache-Control چیست؟
Cache-Control: Max-Age حداکثر زمان ماندگاری و انقضای کش براساس ثانیه است.
۴. منظور از Max Age 3600 Cache-Control چیست؟
Max Age 3600 به این معنا است که پاسخ درخواست را می توان بهمدت ۶۰ دقیقه یا ۳۶۰۰ ثانیه آینده استفاده کرد.