Home > Backend Development > Python Tutorial > How to Cache Using Redis in Django Applications

How to Cache Using Redis in Django Applications

Jennifer Aniston
Release: 2025-03-02 10:10:11
Original
591 people have browsed it

This tutorial demonstrates how to leverage Redis caching to boost the performance of Python applications, specifically within a Django framework. We'll cover Redis installation, Django configuration, and performance comparisons to highlight the benefits of caching.

Introduction to Redis and Caching

Caching significantly improves application speed by storing frequently accessed data in a readily available location (the cache) rather than repeatedly querying slower data sources like databases. Redis, an open-source, in-memory data structure store, excels as a database, cache, and message broker. It dramatically reduces database load by serving data directly from its cache.

Installing Redis

For Ubuntu users, the simplest installation involves these commands:

sudo apt-get update
sudo apt install redis
Copy after login

Verify the installation with:

redis-cli --version
Copy after login

Windows users can utilize the Windows Subsystem for Linux (WSL2). First, enable WSL2 (run as administrator):

Enable-WindowsOptionalFeature -Online -FeatureName Microsoft-Windows-Subsystem-Linux
Copy after login

Install Ubuntu from the Microsoft Store, then launch the Ubuntu terminal and execute:

sudo apt-add-repository ppa:redislabs/redis
sudo apt-get update
sudo apt-get upgrade
sudo apt-get install redis-server
sudo service redis-server restart
Copy after login

How to Cache Using Redis in Django Applications

Django API Example: Caching Product Data

This example demonstrates caching product data in a Django application. We'll use django-redis to interact with Redis.

Prerequisites:

  • Django
  • django-redis
  • Redis
  • loadtest (for performance testing)

Project Setup:

  1. Create a project directory and virtual environment.
  2. Activate the virtual environment and install dependencies:
pip install django==1.9 django-redis djangorestframework
Copy after login
  1. Create a Django project and app:
django-admin startproject django_cache
cd django_cache
python manage.py startapp store
Copy after login
  1. Add store and rest_framework to INSTALLED_APPS in settings.py.

  2. Create the Product model in store/models.py:

from django.db import models

class Product(models.Model):
    name = models.CharField(max_length=255)
    description = models.TextField(null=True, blank=True)
    price = models.IntegerField(null=True, blank=True)
    date_created = models.DateTimeField(auto_now_add=True, blank=True)
    date_modified = models.DateTimeField(auto_now=True, blank=True)

    def __str__(self):
        return self.name

    def to_json(self):
        return {
            'id': self.id,
            'name': self.name,
            'desc': self.description,
            'price': self.price,
            'date_created': self.date_created,
            'date_modified': self.date_modified
        }
Copy after login
  1. Run migrations:
python manage.py makemigrations store
python manage.py migrate
Copy after login
  1. Create a superuser and populate the database with sample data.

Configuring Redis in Django:

Add the following to settings.py:

CACHES = {
    'default': {
        'BACKEND': 'django_redis.cache.RedisCache',
        'LOCATION': 'redis://127.0.0.1:6379/',
        'OPTIONS': {
            'CLIENT_CLASS': 'django_redis.client.DefaultClient',
        }
    }
}
Copy after login

Creating Views and URLs:

Create store/views.py with endpoints for retrieving products (with and without caching):

from rest_framework.decorators import api_view
from rest_framework.response import Response
from django.core.cache import cache
from .models import Product

@api_view(['GET'])
def view_products(request):
    products = Product.objects.all()
    results = [p.to_json() for p in products]
    return Response(results)

@api_view(['GET'])
def view_cached_products(request):
    products = cache.get('products')
    if products:
        return Response(products)
    else:
        products = Product.objects.all()
        results = [p.to_json() for p in products]
        cache.set('products', results)
        return Response(results)
Copy after login

Create store/urls.py:

from django.urls import path
from . import views

urlpatterns = [
    path('', views.view_products),
    path('cached/', views.view_cached_products),
]
Copy after login

Include store/urls in your main urls.py.

Performance Testing with loadtest:

Install loadtest: sudo npm install -g loadtest

Run tests for both endpoints to compare performance. The cached endpoint should show significantly improved requests per second after the initial cache population.

Conclusion:

This tutorial illustrates the straightforward integration of Redis caching into a Django application, resulting in substantial performance gains. Redis's in-memory nature and ease of use make it an excellent choice for improving application speed and reducing server load. Remember to consider caching strategies to optimize your application's performance and resource utilization.

(Post thumbnail image generated by OpenAI DALL-E.)

The above is the detailed content of How to Cache Using Redis in Django Applications. For more information, please follow other related articles on the PHP Chinese website!

Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Latest Articles by Author
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template