سلام و درود به علاقهمندان به دنیای وب! وقتی در مورد کشینگ (Caching) در HTTP صحبت میکنیم، معمولاً به مزایا و چالشهای آن برای سرعت بخشیدن به بارگذاری و تجربه کاربری میپردازیم. اما در پشت پرده، دنیای کشینگ ارتباط بالایی با سایر اجزای وب و برنامهها دارد که در این مقاله میخواهیم به این ارتباطات بپردازیم و بفهمیم چطور میتوان آنها را بهتر مدیریت کرد.
اینکه کشینگ به خودی خود چگونه کار میکند، امری جذاب و البته مفید است، اما در دنیای واقعی وب، ما باید به ارتباط آن با سیستمهای دیگر توجه کنیم. به عنوان مثال، فرض کنید برنامهای دارید که از چندین سرویس دیگر از جمله API ها استفاده میکند. حال اگر هر کدام از این سرویسها کش خود را داشته باشند، چگونه باید همگام سازی شوند تا دادهها به درستی بروزرسانی شوند؟
در RFC 9111، به این نکته پرداخته شده که چه زمانی و چطور کشهای مختلف باهم ارتباط برقرار میکنند. این میتواند زمانی رخ دهد که مثلاً دادهای در کش لوکال شما بر اساس تغییرات انجام شده در سرور اصلی، منسوخ شود و نیاز به بروزرسانی داشته باشد. این نکته زمانی اهمیت بیشتری مییابد که چندین سرویس به یک دادهی مشترک دسترسی دارند.
نقش هدرهای HTTP را نیز نباید نادیده گرفت. این هدرها نه تنها به مرورگرها و سرورها کمک میکنند که بدانند چه محتوایی باید کش شود، بلکه میتوانند اطلاعاتی در مورد طول عمر کش و زمان انقضای آن ارائه دهند. به این ترتیب، توسعهدهندگان با کنترل دقیق این موارد میتوانند از بروز ناسازگاریهای احتمالی جلوگیری کنند.
به عبارت دیگر، در فرآیند کشینگ بهینه، همه چیز در مورد مدیریت صحیح چرخهی عمر دادهها و استفاده بهینه از ریسورسها است. با بهکارگیری اصول کشینگ بهدرستی، نه تنها بار سرورها کاهش پیدا میکند، بلکه کارایی برنامهها افزایش و تجربه کاربری بهبود مییابد.
<meta> هدر مناسب جهت کنترل کش API ها
<p
<meta http-equiv="Cache-Control" content="no-cache, no-store, must-revalidate"></p>
>
برای تطبیق دادههای مشترک
<p>
<script type="text/javascript">
function updateCache() {
// Fetch new data from server
fetch('/api/data').then(response => response.json()).then(data => {
// Update local cache
localStorage.setItem('data', JSON.stringify(data));
});
}
</script>
</p>
هدر Cache-Control
: این هدر تنظیمات کلی کشینگ را مشخص میکند و دستورات میتواند شامل عدم کش شود
داخل <script>
: کدی که با دریافت داده از سرور، کش لوکال را بروزرسانی میکند
تابع updateCache()
: وظیفهی فراخوانی داده و ذخیرهسازی آن در کش لوکال (در اینجا localStorage
) را دارد
دستور fetch
: برای واکشی دادهها به صورت غیرهمگام از یک API یا سرور استفاده میشود