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!

推薦閱讀: