ویژگی تصویر

نحوه پیاده سازی کش در جنگو

  /  Django   /  پیاده سازی کش در Django برای بهبود عملکرد
بنر تبلیغاتی الف

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

در جنگو (Django)، به عنوان یکی از محبوب‌ترین فریمورک‌های وب در دنیای پایتون، قابلیت‌های کش برای بهبود عملکرد و کاهش بار پردازشی سرور به خوبی پشتیبانی شده‌اند. کش در Django می‌تواند به صورت محلی یا برون‌سپاری شده (مثل Redis یا Memcached) تنظیم شود و از این طریق، عملکرد پروژه را به شکل چشم‌گیری افزایش دهد. در این مقاله، قصد داریم به صورت جامع به معرفی کش، پیاده‌سازی و بهینه‌سازی آن در Django بپردازیم تا بتوانید با استفاده از آن سرعت و کارایی پروژه‌های خود را بهبود بخشید.

کش چیست و چرا استفاده می‌شود؟

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

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

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

راه‌اندازی کش محلی در Django

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

1. پیکربندی اولیه کش

ابتدا باید کش را در تنظیمات Django فعال کنید. برای این کار، به فایل settings.py مراجعه کنید و تنظیمات کش محلی را به صورت زیر اضافه کنید:

# settings.py
CACHES = {
    'default': {
        'BACKEND': 'django.core.cache.backends.locmem.LocMemCache',
        'LOCATION': 'unique-snowflake',
    }
}

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

2. استفاده از کش در ویوها

فرض کنید یک ویو دارید که داده‌های سنگینی را از پایگاه داده بازیابی می‌کند و می‌خواهید نتیجه آن را برای چند دقیقه کش کنید. می‌توانید از دکوراتور cache_page استفاده کنید. مثال زیر یک ویو ساده را نشان می‌دهد که نتیجه آن به مدت ۶۰ ثانیه کش می‌شود:

تماشا در حالت تمام صفحه

این کد باعث می‌شود که پس از اولین اجرای ویو، نتیجه آن به مدت ۶۰ ثانیه کش شود و در درخواست‌های بعدی همان نتیجه کش شده ارائه شود، بدون این که مجدداً پردازش شود.

استفاده از Redis برای کش در Django

در پروژه‌های بزرگتر، استفاده از کش محلی کافی نیست. Redis یکی از محبوب‌ترین سیستم‌های ذخیره‌سازی کش است که به دلیل سرعت و کارایی بالا، به ویژه در پروژه‌های پر ترافیک، بسیار کاربردی است. برای استفاده از Redis به عنوان کش در Django، ابتدا نیاز به نصب Redis و کتابخانه‌ی django-redis دارید.

1. نصب Redis و تنظیمات Django

ابتدا Redis را نصب کنید (در سرور یا به صورت محلی). سپس کتابخانه‌ی django-redis را با استفاده از دستور زیر نصب کنید:

pip install django-redis

حالا به تنظیمات Django رفته و تنظیمات Redis را به صورت زیر اضافه کنید:

# settings.py
CACHES = {
    'default': {
        'BACKEND': 'django_redis.cache.RedisCache',
        'LOCATION': 'redis://127.0.0.1:6379/1',
        'OPTIONS': {
            'CLIENT_CLASS': 'django_redis.client.DefaultClient',
        }
    }
}

در اینجا LOCATION آدرس سرور Redis را مشخص می‌کند. در مثال بالا، Redis بر روی localhost با پورت ۶۳۷۹ قرار دارد.

2. کش کردن داده‌ها با Redis

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

استفاده از کش برای کوئری‌های دیتابیس

گاهی اوقات نیاز است تا تنها نتایج یک کوئری خاص از پایگاه داده کش شوند تا در درخواست‌های بعدی نیازی به اجرای دوباره‌ی آن نباشد. Django امکان استفاده از کش برای کوئری‌ها را نیز فراهم کرده است.

در این مثال، نتایج کوئری از یک مدل کش می‌شوند و به مدت یک دقیقه در کش باقی می‌مانند:

تماشا در حالت تمام صفحه

در اینجا، ابتدا سعی می‌کنیم داده‌ها را از کش بازیابی کنیم. اگر داده‌ای در کش موجود نبود، کوئری اجرا می‌شود و سپس نتیجه آن به مدت ۶۰ ثانیه در کش ذخیره می‌شود.

مدیریت و تنظیم مدت زمان کش

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

برای مثال:

cache.set('my_data', data, timeout=300)  # کش به مدت ۵ دقیقه

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

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

منابع:

  1. Django Official Documentation on Caching
  2. Redis Documentation

آیا این مطلب برای شما مفید بود ؟

خیر
بله
بنر تبلیغاتی ج