首頁 > 軟體

Django使用Redis進行快取詳細步驟

2022-08-29 22:06:34

1.背景和意義

伺服器資料非經常更新。若每次都從硬碟讀取一次,浪費伺服器資源、拖慢響應速度。而且資料更新頻率較高,伺服器負擔比較大。若儲存到資料庫,還需要額外建立一張對應的表儲存資料。在Django中建立表通常做法是建立一個模型。看似簡單,但是偵錯麻煩、開發時長久。為了進行伺服器的加速,使用Redis進行快取。

2.設定步驟如下

1,伺服器端安裝 redis

(1)在Windows安裝redis,方便測試
Redis不支援Windows!在它官網寫得很清楚。但是開發環境一般是Windows系統。為了方便開發和偵錯,需要在Windows中安裝Redis。微軟自己弄了Redis的Windows版本。開啟https://github.com/MSOpenTech/redis/releases下載msi安裝包。該版本是64位元。安裝msi過程中,有個選項是否加入系統環境變數,記得勾上。一路下一步,安裝。完成之後開啟cmd,輸入redis-server命令檢視是否可以使用。不可以則重啟一下即可。直接輸入redis-server命令使用的組態檔是安裝目錄下的redis.windows.conf檔案。
若提示錯誤 「ConnectionError: Error 10061 connecting to None:6379」,可以如下操作,開啟cmd輸入如下命令:`redis-cli shutdown` ,再執行redis-server即可。
(2)在ubuntu下安裝,針對部署
`sudo apt-get install redis-server`

2,Redis 存取控制

# 預設情況下,存取 Redis 伺服器是不需要密碼的,為了讓其他伺服器使用同時增加安全性我們需要設定 Redis 伺服器的存取密碼。設定存取密碼為 yourpassword。
# 由於 redis 預設繫結本機的,所以第一步取消該設定:
`sudo vim /etc/redis/redis.conf`
# 用vim開啟該組態檔,然後註釋掉下面這行:
`# bind 127.0.0.1`
# 然後設定登入密碼,用vim開啟組態檔,組態檔較長,命令模式下輸入`/requirepass foobared`快速搜尋該設定項:
# 編輯組態檔
`sudo vim /etc/redis/redis.conf`
# 找到下面這一行並去除註釋(可以搜尋requirepass)
# requirepass foobared 未修改之前
# 修改之後
`requirepass 123456789` # 假設123456789是我的redis密碼
# 修改後重啟伺服器使設定生效:
`sudo /etc/init.d/redis-server restart`
# 此時在登入redis,許可權被控制
root@VM-60-191-ubuntu:~# redis-cli
127.0.0.1:6379> keys *
(error) NOAUTH Authentication required.
# 用密碼登入,具有許可權
root@VM-60-191-ubuntu:~# redis-cli -a 123456789
127.0.0.1:6379> keys *
1) "key2"
# 通過以下命令從另一臺linux伺服器存取redis, password替換為你的密碼,host替換為要存取的伺服器
`redis-cli -a password -h hostip`
# 資料庫的數量是可以設定的,不知道資料庫就是資料庫0,預設情況下是16個。修改redis.conf下的databases指令:
`databases 64`

3,安裝django-redis和settings設定

pip install django-redis

settings.py中加入以下內容,your_host_ip換成你的伺服器地址, yoursecret換成你的伺服器密碼

CACHES = {
    'default': {
        'BACKEND': 'django_redis.cache.RedisCache',
        'LOCATION': 'redis://your_host_ip:6379',
        "OPTIONS": {
            "CLIENT_CLASS": "django_redis.client.DefaultClient",
             "PASSWORD": "yoursecret",
        },
    },
}


REDIS_TIMEOUT=7*24*60*60
CUBES_REDIS_TIMEOUT=60*60
NEVER_REDIS_TIMEOUT=365*24*60*60
# cache中的是必須的,下面三條可有可無(超時設定啥的)

4,測試快取是否成功

為了測試看可否正常使用 redis , 進入django的後臺命令模式:

python manage.py shell

逐條輸入如下命令測試:

from django.core.cache import cache # 引入快取模組
cache.set('v', '555', 60*60)      # 寫入key為v,值為555的快取,有效期30分鐘
cache.has_key('v') # 判斷key為v是否存在
cache.get('v')     # 獲取key為v的快取

到此這篇關於Django使用Redis進行快取詳細流程的文章就介紹到這了,更多相關Django Redis 快取內容請搜尋it145.com以前的文章或繼續瀏覽下面的相關文章希望大家以後多多支援it145.com!


IT145.com E-mail:sddin#qq.com