Django - कैशिंग
किसी चीज़ को कैश करना एक महंगी गणना के परिणाम को बचाने के लिए है, ताकि अगली बार जब आपको इसकी आवश्यकता हो, तो आप इसे प्रदर्शन न करें। निम्नलिखित एक छद्म कोड है जो बताता है कि कैशिंग कैसे काम करता है -
given a URL, try finding that page in the cache
if the page is in the cache:
return the cached page
else:
generate the page
save the generated page in the cache (for next time)
return the generated page
Django अपने स्वयं के कैशिंग सिस्टम के साथ आता है जो आपको जरूरत पड़ने पर फिर से गणना करने से बचने के लिए अपने डायनामिक पृष्ठों को सहेजने देता है। Django कैश फ्रेमवर्क में अच्छी बात यह है कि आप कैश कर सकते हैं -
- एक विशिष्ट दृश्य का आउटपुट।
- एक टेम्पलेट का एक हिस्सा।
- आपकी पूरी साइट
Django में कैश का उपयोग करने के लिए, सबसे पहले यह स्थापित करना है कि कैश कहां रहेगा। कैश फ्रेमवर्क विभिन्न संभावनाएं प्रदान करता है - कैश को डेटाबेस में, फ़ाइल सिस्टम पर या सीधे मेमोरी में सहेजा जा सकता है। में सेटिंग की जाती हैsettings.py आपके प्रोजेक्ट की फाइल।
डेटाबेस में कैश सेट करना
बस प्रोजेक्ट सेटिंग में निम्नलिखित जोड़ दें फ़ाइल -
CACHES = {
'default': {
'BACKEND': 'django.core.cache.backends.db.DatabaseCache',
'LOCATION': 'my_table_name',
}
}
इसके लिए काम करने और सेटिंग को पूरा करने के लिए, हमें कैश टेबल 'my_table_name' बनाने की आवश्यकता है। इसके लिए आपको निम्नलिखित कार्य करने होंगे -
python manage.py createcachetable
फ़ाइल सिस्टम में कैश सेट करना
बस प्रोजेक्ट सेटिंग में निम्नलिखित जोड़ दें फ़ाइल -
CACHES = {
'default': {
'BACKEND': 'django.core.cache.backends.filebased.FileBasedCache',
'LOCATION': '/var/tmp/django_cache',
}
}
मेमोरी में कैश सेट करना
यह कैशिंग का सबसे प्रभावी तरीका है, इसका उपयोग करने के लिए आप पायथन बाइंडिंग लाइब्रेरी के आधार पर निम्नलिखित विकल्पों में से एक का उपयोग कर सकते हैं जिसे आप मेमोरी कैश के लिए चुनते हैं -
CACHES = {
'default': {
'BACKEND': 'django.core.cache.backends.memcached.MemcachedCache',
'LOCATION': '127.0.0.1:11211',
}
}
Or
CACHES = {
'default': {
'BACKEND': 'django.core.cache.backends.memcached.MemcachedCache',
'LOCATION': 'unix:/tmp/memcached.sock',
}
}
पूरी साइट पर कैशिंग
Django में कैश का उपयोग करने का सबसे सरल तरीका पूरी साइट को कैश करना है। यह प्रोजेक्ट सेटिंग्स थिंकपैड में MIDDLEWARE_CLASSES विकल्प को संपादित करके किया जाता है। निम्नलिखित विकल्प में जोड़ा जाना चाहिए -
MIDDLEWARE_CLASSES += (
'django.middleware.cache.UpdateCacheMiddleware',
'django.middleware.common.CommonMiddleware',
'django.middleware.cache.FetchFromCacheMiddleware',
)
ध्यान दें कि यहां आदेश महत्वपूर्ण है, अपडेट को फ़ॉर्च मिडलवेयर से पहले आना चाहिए।
फिर उसी फ़ाइल में, आपको सेट करना होगा -
CACHE_MIDDLEWARE_ALIAS – The cache alias to use for storage.
CACHE_MIDDLEWARE_SECONDS – The number of seconds each page should be cached.
एक दृश्य कैशिंग
यदि आप पूरी साइट को कैश नहीं करना चाहते हैं तो आप एक विशिष्ट दृश्य को कैश कर सकते हैं। यह का उपयोग करके किया जाता हैcache_pageसज्जाकार जो Django के साथ आता है। हम कहते हैं कि हम परिणाम को कैश करना चाहते हैंviewArticles देखें -
from django.views.decorators.cache import cache_page
@cache_page(60 * 15)
def viewArticles(request, year, month):
text = "Displaying articles of : %s/%s"%(year, month)
return HttpResponse(text)
जैसा कि आप देख सकते हैं cache_pageपैरामीटर के रूप में कैच किए जाने के लिए आप चाहते हैं कि सेकंड का नंबर ले। ऊपर हमारे उदाहरण में, परिणाम 15 मिनट के लिए कैश किया जाएगा।
Note - जैसा कि हमने ऊपर देखे गए नक्शे से पहले देखा था -
urlpatterns = patterns('myapp.views',
url(r'^articles/(?P<month>\d{2})/(?P<year>\d{4})/', 'viewArticles', name = 'articles'),)
चूंकि URL पैरामीटर ले रहा है, प्रत्येक अलग कॉल को अलग से कैश किया जाएगा। उदाहरण के लिए, / myapp / articles / 02/2007 के अनुरोध को अलग से / myapp / articles / 03/2008 को कैश किया जाएगा।
किसी दृश्य को कैशिंग सीधे url.py फ़ाइल में भी किया जा सकता है। फिर निम्नलिखित में उपरोक्त के समान परिणाम है। बस अपने myapp / url.py फ़ाइल को संपादित करें और संबंधित मैप किए गए URL (ऊपर) को बदल दें -
urlpatterns = patterns('myapp.views',
url(r'^articles/(?P<month>\d{2})/(?P<year>\d{4})/',
cache_page(60 * 15)('viewArticles'), name = 'articles'),)
और, ज़ाहिर है, अब myapp / views.py में इसकी कोई आवश्यकता नहीं है।
एक टेम्पलेट टुकड़ा कैशिंग
आप किसी टेम्प्लेट के कुछ हिस्सों को भी कैश कर सकते हैं, इसका उपयोग करके किया जाता है cacheटैग। चलो हमारे ले लोhello.html टेम्पलेट -
{% extends "main_template.html" %}
{% block title %}My Hello Page{% endblock %}
{% block content %}
Hello World!!!<p>Today is {{today}}</p>
We are
{% if today.day == 1 %}
the first day of month.
{% elif today == 30 %}
the last day of month.
{% else %}
I don't know.
{%endif%}
<p>
{% for day in days_of_week %}
{{day}}
</p>
{% endfor %}
{% endblock %}
और कंटेंट ब्लॉक को कैश करने के लिए, हमारा टेम्प्लेट बन जाएगा -
{% load cache %}
{% extends "main_template.html" %}
{% block title %}My Hello Page{% endblock %}
{% cache 500 content %}
{% block content %}
Hello World!!!<p>Today is {{today}}</p>
We are
{% if today.day == 1 %}
the first day of month.
{% elif today == 30 %}
the last day of month.
{% else %}
I don't know.
{%endif%}
<p>
{% for day in days_of_week %}
{{day}}
</p>
{% endfor %}
{% endblock %}
{% endcache %}
जैसा कि आप ऊपर देख सकते हैं, कैश टैग 2 पैरामीटर लेगा - जिस समय आप ब्लॉक को कैश किया जाना चाहते हैं (सेकंड में) और कैश टुकड़े को दिया जाने वाला नाम।