redis相信大家都很熟悉了,和memcached一樣是一個高效能的key-value資料庫,至於什麼是快取伺服器,度娘都有很明白的介紹了,我在這裡就不一一介紹了。
那我們一般什麼情況下才會使用快取伺服器呢?可不是什麼情況都需要的哦,一般來說是在需要頻繁對一個字段讀取的時候才會需要將這個字段放入到緩存伺服器上,而且由於key-value數據庫一般只是放很簡單的數據,所以在選擇已儲存的物件的時候要注意選擇好。
下面我就來介紹如何在Django中設定使用redis資料庫,首先是先安裝redis了,在Ubuntu中執行下面這句指令:
#安裝Redis伺服器端
sudo apt-get install redis-server
Django中使用redis,也需要安裝redis for Django的插件:
pip install django-redis
這是一個開源的項目,github位址是https://github.com/niwibe/django-redis,感謝作者。
那麼現在就是在Django的settings中配置了。
CACHES = { 'default': { 'BACKEND': 'redis_cache.cache.RedisCache', 'LOCATION': '127.0.0.1:6379', "OPTIONS": { "CLIENT_CLASS": "redis_cache.client.DefaultClient", }, }, } REDIS_TIMEOUT=7*24*60*60 CUBES_REDIS_TIMEOUT=60*60 NEVER_REDIS_TIMEOUT=365*24*60*60
其實只是需要CACHES中的那幾條就可以了,後面這三句可以不需要的,只是我後面的例子裡需要用到,我就在這裡配置了。
好了,現在連接和設定都已經完成了,那麼在專案中該如何使用呢?接下來看下面這段例子。
from django.conf import settings from django.core.cache import cache #read cache user id def read_from_cache(self, user_name): key = 'user_id_of_'+user_name value = cache.get(key) if value == None: data = None else: data = json.loads(value) return data #write cache user id def write_to_cache(self, user_name): key = 'user_id_of_'+user_name cache.set(key, json.dumps(user_name), settings.NEVER_REDIS_TIMEOUT)
透過上面的這兩個方法就可以實現對redis的讀取操作了,只需要將需要的字段當參數傳入到方法中就好了。
那麼之前提到的memcached呢?其實也是一樣的配置:
CACHES = { 'default': { 'BACKEND': 'django.core.cache.backends.memcached.MemcachedCache', 'LOCATION': '127.0.0.1:11211', } }
當然用法也是跟我上面的例子是一樣的了。其實對於redis這樣的快取伺服器來說,設定都是很簡單的,而具體的使用也不難,官網上面也有很多簡單明了的例子可以供我們參考,只有一點需要注意的,那就是對於要將什麼樣的資訊保存到redis才是我們真正需要關心的。