redis作為一個快取資料庫,在各方面都有很大作用,Python支援操作redis,如果你使用Django,有一個專為Django搭配的redis庫,即django- redis
pip install django-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 |
Django預設的Session是儲存在sql資料庫裡的,但我們都知道普通的資料會被資料儲存在硬碟上,速度沒有那麼快,如果想改成儲存在redis裡,只需要在設定檔裡設定一下就行
SESSION_ENGINE = "django.contrib.sessions.backends.cache" SESSION_CACHE_ALIAS = "default"
連線逾時的秒數可以在設定項裡指定,SOCKET_CONNECT_TIMEOUT表示連線redis的超時時間,SOCKET_TIMEOUT表示使用redis進行讀寫操作的超時時間
CACHES = { "default": { # ... "OPTIONS": { "SOCKET_CONNECT_TIMEOUT": 5, # 连接redis超时时间,单位为秒 "SOCKET_TIMEOUT": 5, # redis读写操作超时时间,单位为秒 } } }
#如果你想使用預設的redis ,也就是在設定檔裡設定的別名為「default」的redis,可以引用django.core.cache裡的cache
from django.core.cache import cache cache.set("name", "冰冷的希望", timeout=None) print(cache.get("name"))
#當你在設定檔裡寫了多個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
使用連接池的好處是不用管理連接對象,它會自動創建一些連接物件並且盡可能重複使用,所以相當來說效能會好一點
要使用連線池,首先要在Django的設定檔裡寫上連線池的最大連接數
CACHES = { "default": { "BACKEND": "django_redis.cache.RedisCache", ... "OPTIONS": { "CONNECTION_POOL_KWARGS": {"max_connections": 100} } } }
我們可以透過連接別名確定要使用哪個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)
Django-redis預設的連接的類別是DefaultClient,如果你有更高的自訂需求,可以新建一個自己的類,繼承ConnectionPool
from redis.connection import ConnectionPool class MyPool(ConnectionPool): pass
有了這個類別之後還需要在Django的設定檔裡指定它
"OPTIONS": { "CONNECTION_POOL_CLASS": "XXX.XXX.MyPool", }
以上是django redis怎麼使用的詳細內容。更多資訊請關注PHP中文網其他相關文章!