django redis的使用方法詳解
1.說明
redis作為一個緩存數據庫,在各方面都有很大作用,Python支持操作redis,如果你使用Django,有一個專為Django搭配的redis庫,即django-redis
2.安裝
pip install django-redis
3.配置
3.1 配置redis
打開Django的配置文件,比如說setting.py,裡面設置CACHES項
CACHES = { "default": { "BACKEND": "django_redis.cache.RedisCache", "LOCATION": "redis://127.0.0.1:6379/1", "OPTIONS": { "CLIENT_CLASS": "django_redis.client.DefaultClient", } } }
一個CACHES裡可以配置多個redis連接信息,每一個都有自己的別名(alias),上面的“default”就是別名,到時候可以通過不同別名連接不同redis數據庫
LOCATION是連接的信息,包括ip端口用戶密碼等,如果不需要用戶密碼則可以省略不寫,django-redis支持三種連接協議,如下
協議 | 說明 | 舉例 |
---|---|---|
redis:// | 普通的TCP套接字連接 | redis://[[username]:[password]]@localhost:6379/0 |
rediss | SSL方式的TCP套接字連接 | rediss://[[username]:[password]]@localhost:6379/0 |
rediss:// | Unix域套接字連接 | unix://[[username]:[password]]@/path/to/socket.sock?db=0 |
3.2 使用redis存儲session
Django默認的Session是存儲在sql數據庫裡的,但我們都知道普通的數據會被數據存儲在硬盤上,速度沒有那麼快,如果想改成存儲在redis裡,隻需要在配置文件裡配置一下就行
SESSION_ENGINE = "django.contrib.sessions.backends.cache" SESSION_CACHE_ALIAS = "default"
3.3 redis連接超時時間設置
連接超時的秒數可以在配置項裡指定,SOCKET_CONNECT_TIMEOUT表示連接redis的超時時間,SOCKET_TIMEOUT表示使用redis進行讀寫操作的超時時間
CACHES = { "default": { # ... "OPTIONS": { "SOCKET_CONNECT_TIMEOUT": 5, # 連接redis超時時間,單位為秒 "SOCKET_TIMEOUT": 5, # redis讀寫操作超時時間,單位為秒 } } }
4.使用redis
4.1 使用默認redis
如果你想使用默認的redis,也就是在配置文件裡設置的別名為“default”的redis,可以引用django.core.cache裡的cache
from django.core.cache import cache cache.set("name", "冰冷的希望", timeout=None) print(cache.get("name"))
4.2 使用指定redis(原生redis)
當你在配置文件裡寫瞭多個redis連接,可以通過別名指定要使用哪個redis
from django_redis import get_redis_connection redis_conn = get_redis_connection("chain_info") redis_conn.set("name", "icy_hope") print(redis_conn.get("name"))
要註意,通過get_redis_connection()獲取得到的客戶端是原生Redis客戶端,雖然基本上支持所有的原生redis命令,但它返回的數據是byte類型,你需要自己decode
5.連接池
使用連接池的好處是不用管理連接對象,它會自動創建一些連接對象並且盡可能重復使用,所以相當來說性能會好一點
5.1 配置連接池
要使用連接池,首先要在Django的配置文件裡寫上連接池的最大連接數
CACHES = { "default": { "BACKEND": "django_redis.cache.RedisCache", ... "OPTIONS": { "CONNECTION_POOL_KWARGS": {"max_connections": 100} } } }
5.2 使用連接池
我們可以通過連接別名確定要使用哪個redis,然後正常執行命令就行,我們不用在乎它創建瞭哪些連接實例,但你可以通過connection_pool的_created_connections屬性查看當前創建瞭多少個連接實例
from django_redis import get_redis_connection redis_conn = get_redis_connection("default") redis_conn.set("name", "冰冷的希望") print(redis_conn.get("name")) # 查看目前已創建的連接數量 connection_pool = redis_conn.connection_pool print(connection_pool._created_connections)
5.3 自定義連接池
Django-redis默認的連接的類是DefaultClient,如果你有更高的定制需求,可以新建一個自己的類,繼承ConnectionPool
from redis.connection import ConnectionPool class MyPool(ConnectionPool): pass
有瞭這個類之後還需要在Django的配置文件裡指定它
"OPTIONS": { "CONNECTION_POOL_CLASS": "XXX.XXX.MyPool", }
到此這篇關於django redis的使用方法詳解的文章就介紹到這瞭,更多相關django redis使用內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!
推薦閱讀:
- Django使用Redis進行緩存詳細步驟
- Go實現Redis連接池方法
- Python實現各種中間件的連接
- Redis 異常 read error on connection 的解決方案
- 非常全面的Python常見基礎面試題及答案