django redis的使用方法詳解
1.說明
redis作為一個(gè)緩存數(shù)據(jù)庫,在各方面都有很大作用,Python支持操作redis,如果你使用Django,有一個(gè)專為Django搭配的redis庫,即django-redis
2.安裝
pip install django-redis
3.配置
3.1 配置redis
打開Django的配置文件,比如說setting.py,里面設(shè)置CACHES項(xiàng)
CACHES = {
"default": {
"BACKEND": "django_redis.cache.RedisCache",
"LOCATION": "redis://127.0.0.1:6379/1",
"OPTIONS": {
"CLIENT_CLASS": "django_redis.client.DefaultClient",
}
}
}
一個(gè)CACHES里可以配置多個(gè)redis連接信息,每一個(gè)都有自己的別名(alias),上面的“default”就是別名,到時(shí)候可以通過不同別名連接不同redis數(shù)據(jù)庫
LOCATION是連接的信息,包括ip端口用戶密碼等,如果不需要用戶密碼則可以省略不寫,django-redis支持三種連接協(xié)議,如下
| 協(xié)議 | 說明 | 舉例 |
|---|---|---|
| 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默認(rèn)的Session是存儲在sql數(shù)據(jù)庫里的,但我們都知道普通的數(shù)據(jù)會(huì)被數(shù)據(jù)存儲在硬盤上,速度沒有那么快,如果想改成存儲在redis里,只需要在配置文件里配置一下就行
SESSION_ENGINE = "django.contrib.sessions.backends.cache" SESSION_CACHE_ALIAS = "default"
3.3 redis連接超時(shí)時(shí)間設(shè)置
連接超時(shí)的秒數(shù)可以在配置項(xiàng)里指定,SOCKET_CONNECT_TIMEOUT表示連接redis的超時(shí)時(shí)間,SOCKET_TIMEOUT表示使用redis進(jìn)行讀寫操作的超時(shí)時(shí)間
CACHES = {
"default": {
# ...
"OPTIONS": {
"SOCKET_CONNECT_TIMEOUT": 5, # 連接redis超時(shí)時(shí)間,單位為秒
"SOCKET_TIMEOUT": 5, # redis讀寫操作超時(shí)時(shí)間,單位為秒
}
}
}
4.使用redis
4.1 使用默認(rèn)redis
如果你想使用默認(rèn)的redis,也就是在配置文件里設(shè)置的別名為“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)
當(dāng)你在配置文件里寫了多個(gè)redis連接,可以通過別名指定要使用哪個(gè)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命令,但它返回的數(shù)據(jù)是byte類型,你需要自己decode
5.連接池
使用連接池的好處是不用管理連接對象,它會(huì)自動(dòng)創(chuàng)建一些連接對象并且盡可能重復(fù)使用,所以相當(dāng)來說性能會(huì)好一點(diǎn)
5.1 配置連接池
要使用連接池,首先要在Django的配置文件里寫上連接池的最大連接數(shù)
CACHES = {
"default": {
"BACKEND": "django_redis.cache.RedisCache",
...
"OPTIONS": {
"CONNECTION_POOL_KWARGS": {"max_connections": 100}
}
}
}
5.2 使用連接池
我們可以通過連接別名確定要使用哪個(gè)redis,然后正常執(zhí)行命令就行,我們不用在乎它創(chuàng)建了哪些連接實(shí)例,但你可以通過connection_pool的_created_connections屬性查看當(dāng)前創(chuàng)建了多少個(gè)連接實(shí)例
from django_redis import get_redis_connection
redis_conn = get_redis_connection("default")
redis_conn.set("name", "冰冷的希望")
print(redis_conn.get("name"))
# 查看目前已創(chuàng)建的連接數(shù)量
connection_pool = redis_conn.connection_pool
print(connection_pool._created_connections)5.3 自定義連接池
Django-redis默認(rèn)的連接的類是DefaultClient,如果你有更高的定制需求,可以新建一個(gè)自己的類,繼承ConnectionPool
from redis.connection import ConnectionPool class MyPool(ConnectionPool): ? ? pass
有了這個(gè)類之后還需要在Django的配置文件里指定它
"OPTIONS": {
"CONNECTION_POOL_CLASS": "XXX.XXX.MyPool",
}
到此這篇關(guān)于django redis的使用方法詳解的文章就介紹到這了,更多相關(guān)django redis使用內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
python利用pymysql和openpyxl實(shí)現(xiàn)操作MySQL數(shù)據(jù)庫并插入數(shù)據(jù)
這篇文章主要為大家詳細(xì)介紹了如何使用Python連接MySQL數(shù)據(jù)庫,并從Excel文件中讀取數(shù)據(jù),將其插入到MySQL數(shù)據(jù)庫中,有需要的小伙伴可以參考一下2023-10-10
Python接口自動(dòng)化測試的實(shí)現(xiàn)
這篇文章主要介紹了Python接口自動(dòng)化測試的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-08-08
python讀取目錄下所有的jpg文件,并顯示第一張圖片的示例
今天小編就為大家分享一篇python讀取目錄下所有的jpg文件,并顯示第一張圖片的示例,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-06-06
如何解決cmd運(yùn)行python提示不是內(nèi)部命令
在本篇文章里小編給大家整理了關(guān)于如何解決cmd運(yùn)行python提示不是內(nèi)部命令的相關(guān)內(nèi)容,有興趣的朋友們學(xué)習(xí)下。2020-07-07
python向企業(yè)微信發(fā)送文字和圖片消息的示例
這篇文章主要介紹了python向企業(yè)微信發(fā)送文字和圖片消息的示例,幫助大家更好的理解和使用python,感興趣的朋友可以了解下2020-09-09
Python圖像處理庫Pillow的簡單實(shí)現(xiàn)
本文主要介紹了Python圖像處理庫Pillow的簡單實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2023-06-06

