Django使用Redis進行緩存詳細步驟

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 緩存內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!

推薦閱讀: