本教程演示瞭如何利用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中文網其他相關文章!