本文首發于公眾號:Hunter后端
原文鏈接:Django筆記三十三之快取操作
這一節介紹一下如何在 Django 中使用 redis 做快取操作,
在 Django 中可以有很多種方式做快取,比如資料庫,比如服務器檔案,或者記憶體,這里介紹用的比較多的使用 redis 作為快取,
這篇筆記主要內容如下:
- 依賴安裝
- settings.py 配置
- 快取操作用法
- 快取版本控制
- cache 用作 session backend
- 清除 redis 里全部資料
- 批量查詢與洗掉
其中,redis 的安裝我們在 celery 系列筆記的第一篇已經介紹過了,可以直接使用 docker 來操作,這里不做贅述了,
1、依賴安裝
Django 連接 redis 這里用到一個模塊,django-redis,接下來我們用 pip 來安裝:
pip3 install django-redis
2、settings.py 配置
然后在 settings.py 里設定 CACHES 引數即可使用:
# hunter/settings.py
CACHES = {
"default": {
"BACKEND": "django_redis.cache.RedisCache",
"LOCATION": "redis://:[email protected]:6380/2",
"OPTIONS": {
"CLIENT_CLASS": "django_redis.client.DefaultClient",
}
}
}
在這里 redis 的埠我設定成了 6380,密碼我設為了 123456,
如果沒有密碼,LOCATION 的引數為 redis://127.0.0.1:6380/2
當然,如果密碼也可以和 url 分離配置,我們可以放到 OPTIONS 引數里:
# hunter/settings.py
CACHES = {
"default": {
"BACKEND": "django_redis.cache.RedisCache",
"LOCATION": "redis://127.0.0.1:6380/2",
"OPTIONS": {
"CLIENT_CLASS": "django_redis.client.DefaultClient",
"PASSWORD": "123456",
}
}
}
3、快取操作用法
在上面的配置都設定好之后,可以正式開始我們的快取操作了,
其實關于快取,我們可以快取視圖,模板等,但是一般來說,都是快取更細粒度的資料,比如某個需要經常被訪問到的、或者需要經過一些時間進行計算得出結果的資料,可以將其存入快取來提高介面的訪問效率,
以下是快取操作的一些用法介紹:
#引入 cache 快取模塊
from django.core.cache import cache
#創建一條快取資訊
cache.set("key", "value", 60)
###上述陳述句釋義:Redis 是一種以 key-value 形式存盤的非關系型資料庫,
###所以上述陳述句表示的是向 Redis 中存入一條記錄,到期時間是60秒后,以秒為單位
#查看是否有某條快取資訊
cache.has_key("key")
###回傳的結果是布爾型 True or False
#如果沒有就創建一條快取資訊
cache.get_or_set("k", 3, 60)
### 回傳的是 k 這條記錄的 value 值
#查詢某條快取記錄
cache.get("k")
### 如果沒有這條快取資訊 則不回傳
#查詢某條記錄,沒有則回傳特定值
cache.get("k", False)
#同時創建多條記錄
cache.set_many({"d":1, "e": 3, "f": 6})
### 輸入引數為一個 字典
#同時查詢多條記錄
cache.get_many(["a", "v", "e"])
### 回傳的結果是一個有序字典 OrderedDict
#洗掉某條快取記錄
cache.delete("a")
### 輸入引數為該記錄的 key
#洗掉多條快取記錄
cache.delete(["a", "b", "c"])
#清除所有快取記錄
cache.clear()
#對快取value為數字的記錄進行操作
cache.set("num", 1)
#對快取記錄+1
cache.incr("num")
#對快取記錄 +n
cache.incr("num", 5)
#對快取記錄-1
cache.decr("num")
#對快取記錄-n
cache.decr("num", 8)
# 對 key 設定新的過期時間為 20s
cache.touch("num", 20)
# 除了 touch 還有 expire 函式可以設定過期時間
cache.expire("num", 10)
# 設定永不超時,timeout=None
cache.set("a", 1, timeout=None)
# 設定永不過期,還可以使用 persist
cache.persist("a")
# 獲取 key 的剩余時間,回傳的是0 表示已過期或者不存在key,否則回傳的是剩余的秒數,如果回傳的是 None 表示該資料永不過期
cache.ttl("a")
4、快取版本控制
如果我們執行 cache.set("a", 1)
這條命令,再去 redis 的命令列通過 keys * 查看所有資料,可以看到一條 key 為 :1:a
的資料,
但是我們去通過 cache.get("a")
的時候,發現可以直接獲取到資料,這就是后臺為我們自動處理的版本控制,前面的 :1
就表示版本數是 1,
當我們執行 cache.set()
命令時,其實后面還有一個 version 引數,默認為 1,所以下面兩個命令是等效的:
cache.set("a", 1)
cache.set("a", 1, version=1)
所以如果有版本的需求我們可以通過這個引數來控制,
快取版本遞增或遞減
比如對于一個 version=2 的資料,我們可以這樣操作:
cache.set("a", 1, version=2)
# 版本數 +1
cache.incr_version("a")
# 版本數 -1
cache.decr_version("a")
但是注意,當 version 可以減少到 0,但是不能再往下減少了,再減少的話就會報錯了,
5、cache 用作 session backend
在上一節中,我們介紹了默認使用資料庫表作為 session 的存盤形式,我們還可以使用 cache 來用作存盤,
只需要在 settings.py 中加入下面這兩條命令:
SESSION_ENGINE = "django.contrib.sessions.backends.cache"
SESSION_CACHE_ALIAS = "default"
重新運行系統,使用前一篇筆記的代碼,呼叫登錄介面,然后就可以在 redis 的互動界面,通過 keys * ,就可以看到這條 session 記錄在 redis 里已經有保存了,
6、清除 redis 里全部資料
洗掉 redis 中 cache 里全部 key-value 資料,可以使用下面的命令:
from django_redis import get_redis_connection
get_redis_connection("default").flushall()
7、批量查詢與洗掉
我們可以通過通配符的方式來查詢或者洗掉指定的鍵,
比如我們創建下面幾條資料:
cache.set("a", 1)
cache.set("a_1", 1)
cache.set("a_2", 1)
然后可以通過 a* 的方式來獲取這幾條資料的 key:
cache.keys("a*")
# 回傳陣列:["a", "a2", "a3"]
但是官方檔案不推薦這種方式,尤其是在 redis 資料量大的情況下,推薦的是 iter_keys() 函式,回傳一個迭代器
for key in cache.iter_keys("a*"):
print(key)
洗掉 key
批量洗掉的話使用的是 delete_pattern() 函式,
cache.delete_pattern("a*")
以上就是本篇筆記全部內容,來源于兩篇官方檔案:
https://django-redis-chs.readthedocs.io/zh_CN/latest/#
https://docs.djangoproject.com/zh-hans/3.2/topics/cache/
如果想獲取更多后端相關文章,可掃碼關注閱讀:
轉載請註明出處,本文鏈接:https://www.uj5u.com/houduan/551492.html
標籤:其他
上一篇:Markdown基本語法
下一篇:返回列表