背景和意義
服務器數據非經常更新。若每次都從硬盤讀取一次,浪費服務器資源、拖慢響應速度。而且數據更新頻率較高,服務器負擔比較大。若保存到數據庫,還需要額外建立一張對應的表存儲數據。在Django中建立表通常做法是建立一個模型。看似簡單,問題調試麻煩、開發時長久。為了進行服務器的加速,使用Redis進行緩存。
配置步驟如下
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
1
再執行redis-server即可。
(2)在ubuntu下安裝,針對部署
sudo apt-get install redis-server
1
安裝完成后,Redis服務器會自動啟動,我們檢查Redis服務器程序
root@VM-60-191-ubuntu:~# ps -aux|grep redis
redis 30543 0.1 0.7 37228 6724 ? Ssl 14:03 0:00 /usr/bin/redis- server 127.0.0.1:6379
root 30660 0.0 0.1 11288 924 pts/1 S+ 14:04 0:00 grep --color=au to redis
1
2
3
查看運行狀態
root@VM-60-191-ubuntu:~# sudo /etc/init.d/redis-server status
* redis-server.service - Advanced key-value store
Loaded: loaded (/lib/systemd/system/redis-server.service; enabled; vendor preset: enabled)
Active: active (running) since Mon 2018-03-26 14:03:03 CST; 3min 1s ago
Docs: http://redis.io/documentation,
man:redis-server(1)
Main PID: 30543 (redis-server)
CGroup: /system.slice/redis-server.service
`-30543 /usr/bin/redis-server 127.0.0.1:6379
Mar 26 14:03:03 VM-60-191-ubuntu systemd[1]: Starting Advanced key-value store...
Mar 26 14:03:03 VM-60-191-ubuntu run-parts[30533]: run-parts: executing /etc/redis/redis-server....le
Mar 26 14:03:03 VM-60-191-ubuntu run-parts[30544]: run-parts: executing /etc/redis/redis-server....le
Mar 26 14:03:03 VM-60-191-ubuntu systemd[1]: Started Advanced key-value store.
Hint: Some lines were ellipsized, use -l to show in full.
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
通過命令行客戶端訪問
root@VM-60-191-ubuntu:~# redis-cli
#查看幫助
127.0.0.1:6379> help
redis-cli 3.0.6
Type: "help @<group>" to get a list of commands in <group>
"help <command>" for help on <command>
"help <tab>" to get a list of possible help topics
"quit" to exit
#設置k-v記錄
127.0.0.1:6379> set key1 "helloword"
OK
#根據鍵查找記錄
127.0.0.1:6379> get key1
"helloword"
#展示所有的鍵
127.0.0.1:6379> keys *
1) "key1"
#刪除鍵
127.0.0.1:6379> del key1
(integer) 1
127.0.0.1:6379> keys *
(empty list or set)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
2,Redis訪問控制
默認情況下,訪問Redis服務器是不需要密碼的,為了讓其他服務器使用同時增加安全性我們需要設置Redis服務器的訪問密碼。設置訪問密碼為yourpassword。
由於redis默認綁定本機的,所以第一步取消該設置:
sudo vim /etc/redis/redis.conf
1
用vim打開該配置文件,然后注釋掉下面這行:
#bind 127.0.0.1
1
然后設置登密碼,用vim打開配置文件,配置文件較長,命令模式下輸入/requirepass foobared快速搜索該配置項:
#編輯配置文件
sudo vim /etc/redis/redis.conf
#找到下面這一行並去除注釋(可以搜索requirepass)我的 是396行
#requirepass foobared 未修改之前
#修改之后
requirepass 123456789 #假設123456789是我的redis密碼
1
2
3
4
5
6
7
修改后重啟服務器使配置生效:
root@VM-60-191-ubuntu:~# sudo /etc/init.d/redis-server restart
[ ok ] Restarting redis-server (via systemctl): redis-server.service.
1
2
此時在登錄redis,權限被控制
root@VM-60-191-ubuntu:~# redis-cli
127.0.0.1:6379> keys *
(error) NOAUTH Authentication required.
1
2
3
4
用密碼登錄,具有權限
root@VM-60-191-ubuntu:~# redis-cli -a 941020
127.0.0.1:6379> keys *
1) "key2"
1
2
3
通過以下命令從另一台linux服務器訪問redis,password替換為你的密碼,host替換為要訪問的服務器
redis-cli -a password -h hostip
1
數據庫的數量是可以配置的,不知道數據庫就是數據庫0,默認情況下是16個。修改redis.conf下的databases指令:
databases 64
1
3,安裝django-redis和settings配置
pip install django-redis
1
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
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
cache中的是必須的,下面三條可有可無
4,測試緩存是否成功
本步驟非必須,只是為了測試看可否正常使用redis。
進入django的后台命令模式:
python manage.py shell
1
逐條輸入如下命令測試:
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的緩存
1
2
3
4
更多命令請查看網址:django_redis中文文檔