一、基本使用
import redis # 普通連接 conn = redis.Redis(host="192.168.23.166", port=6379,password="123456") conn.set("x1","hello",ex=5) # ex代表seconds,px代表ms val = conn.get("x1") print(val) import redis # 連接池 pool = redis.ConnectionPool(host="192.168.23.166", port=6379,password="123456",max_connections=1024) conn = redis.Redis(connection_pool=pool) print(conn.get("x1"))
全局配置
# redis配置 CACHES = { "default": { "BACKEND": "django_redis.cache.RedisCache", "LOCATION": "redis://127.0.0.1:6379", "OPTIONS": { "CLIENT_CLASS": "django_redis.client.DefaultClient", "CONNECTION_POOL_KWARGS": {"max_connections": 100} # "PASSWORD": "密碼", } } }
二、緩存級別
1.全棧緩存
在settings.py配置文件中添加 MIDDLEWARE = [ 'django.middleware.cache.UpdateCacheMiddleware', 'django.middleware.security.SecurityMiddleware', 'django.contrib.sessions.middleware.SessionMiddleware', 'django.middleware.common.CommonMiddleware', 'django.middleware.csrf.CsrfViewMiddleware', 'django.contrib.auth.middleware.AuthenticationMiddleware', 'django.contrib.messages.middleware.MessageMiddleware', 'django.middleware.clickjacking.XFrameOptionsMiddleware', 'django.middleware.cache.FetchFromCacheMiddleware', ] 其中'django.middleware.cache.UpdateCacheMiddleware'位於列表第一位,因為views函數處理后,還需要中間件進行處理,中間件處理后,最終的數據才是想要的結果。 'django.middleware.cache.FetchFromCacheMiddleware'位於列表最末,因為只有經過中間件認證或者其他處理后,才是合法、有效的請求,所以查詢需要放到中間件最末。
2.視圖緩存
from django.views.decorators.cache import cache_page @cache_page(60*15) def index(request): return HttpResponse("ok") # 緩存15分鍾
3.元素緩存
a.引入templatetag {% cache %} b.使用緩存 {% cache 5000 緩存key %} 緩存內容 {% endcache %}
三、基本操作
redis hget hgetall hincrby("k2","age",amount=num) # num為正數或負數 hincrbyfloat 如果k4對應數據又1000w條數據,打印全部 hscan_iter("k4",count=100) redis操作對象時,只有第一層value支持:list、dict.........