本教程演示了如何利用Redis缓存以提高Python应用程序的性能,特别是在Django框架内。 我们将介绍REDIS安装,Django配置和性能比较,以突出缓存的好处。
> REDIS和CACHING简介> 通过将常见的数据存储在随时可用的位置(缓存)中,而不是反复查询较慢的数据源(如数据库),可以显着提高应用速度。 Redis是一个开源的内存数据结构存储,擅长于数据库,缓存和消息代理。 它通过直接从其高速缓存提供数据来大大减少数据库负载。
对于Ubuntu用户而言,最简单的安装涉及以下命令:
Windows用户可以利用Windows子系统进行Linux(WSL2)。 首先,启用WSL2(作为管理员运行):
sudo apt-get update sudo apt install redis
>从Microsoft Store安装Ubuntu,然后启动Ubuntu终端并执行:
redis-cli --version
Enable-WindowsOptionalFeature -Online -FeatureName Microsoft-Windows-Subsystem-Linux
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
>
与redis进行交互。>
>先决条件:django-redis
django
django-redis
(用于性能测试)loadtest
创建一个项目目录和虚拟环境。 激活虚拟环境并安装依赖项:
pip install django==1.9 django-redis djangorestframework
django-admin startproject django_cache cd django_cache python manage.py startapp store
store
在rest_framework
中创建INSTALLED_APPS
模型:settings.py
>
Product
运行迁移: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 }
python manage.py makemigrations store python manage.py migrate
创建视图和URL:
带有用于检索产品的端点(带有和不缓存):settings.py
CACHES = { 'default': { 'BACKEND': 'django_redis.cache.RedisCache', 'LOCATION': 'redis://127.0.0.1:6379/', 'OPTIONS': { 'CLIENT_CLASS': 'django_redis.client.DefaultClient', } } }
在您的主
中包括。
store/views.py
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)
store/urls.py
>
from django.urls import path from . import views urlpatterns = [ path('', views.view_products), path('cached/', views.view_cached_products), ]
store/urls
>运行两个端点的测试以比较性能。 缓存的端点应在最初的缓存人群后每秒显示明显改善的请求。
结论:
(openai dall-e产生的缩略图图像。)
>
以上是如何在django应用程序中使用redis缓存的详细内容。更多信息请关注PHP中文网其他相关文章!