django中使用memcached示例詳解
什麼是memcached:
- memcached之前是danga的一個項目,最早是為LiveJournal服務的,當初設計師為瞭加速LiveJournal訪問速度而開發的,後來被很多大型項目采用。官網是www.danga.com或者是memcached.org。
- Memcached是一個高性能的分佈式的內存對象緩存系統,全世界有不少公司采用這個緩存項目來構建大負載的網站,來分擔數據庫的壓力。Memcached是通過在內存裡維護一個統一的巨大的hash表,memcached能存儲各種各樣的數據,包括圖像、視頻、文件、以及數據庫檢索的結果等。簡單的說就是將數據調用到內存中,然後從內存中讀取,從而大大提高讀取速度。
哪些情況下適合使用Memcached:存儲驗證碼(圖形驗證碼、短信驗證碼)、登錄session等所有不是至關重要的數據。
安裝和啟動memcached:
windows
安裝:memcached.exe -d install。
啟動:memcached.exe -d start。
linux(ubuntu)
安裝:sudo apt install memcached
啟動: cd /usr/local/memcached/bin ./memcached -d start
可能出現的問題:
提示你沒有權限:在打開cmd的時候,右鍵使用管理員身份運行。
提示缺少pthreadGC2.dll文件:將pthreadGC2.dll文件拷貝到windows/System32.
不要放在含有中文的路徑下面。
啟動memcached:
如果想要使用以上參數來指定一些配置信息,那麼不能使用service memcached start,而應該使用/usr/bin/memcached的方式來運行。比如/usr/bin/memcached -u memcache -m 1024 -p 11222 start。
- -d:這個參數是讓memcached在後臺運行。
- -m:指定占用多少內存。以M為單位,默認為64M。
- -p:指定占用的端口。默認端口是11211。
- -l:別的機器可以通過哪個ip地址連接到我這臺服務器。如果是通過service memcached start的方式,那麼隻能通過本機連接。如果想要讓別的機器連接,就必須設置-l 0.0.0.0。
telnet操作memcached:
telnet ip地址 [11211]
添加數據:
set
語法:
set key flas(是否壓縮) timeout value_length value
示例: set username 0 60 7 zhiliao
add
語法:
add key flas(0) timeout value_length value
示例: add username 0 60 7 xiaotuo set和add的區別:add是隻負責添加數據,不會去修改數據。如果添加的數據的key已經存在瞭,則添加失敗,如果添加的key不存在,則添加成功。而set不同,如果memcached中不存在相同的key,則進行添加,如果存在,則替換。
獲取數據:
語法: get key
示例: get username
刪除數據:
語法: delete key
示例: delete username
flush_all:刪除memcached中的所有數據。
查看memcached的當前狀態:
語法:stats。
通過python操作memcached:
- 安裝:python-memcached:pip install python-memcached。
- 建立連接: import memcache mc = memcache.Client(['127.0.0.1:11211','192.168.174.130:11211'],debug=True)
- 設置數據: mc.set('username','hello world',time=60*5) mc.set_multi({'email':'[email protected]','telphone':'111111'},time=60*5)
- 獲取數據: mc.get('telphone')
- 刪除數據: mc.delete('email')
- 自增長: mc.incr('read_count')
- 自減少: mc.decr('read_count')
memcached的安全性:
memcached的操作不需要任何用戶名和密碼,隻需要知道memcached服務器的ip地址和端口號即可。因此memcached使用的時候尤其要註意他的安全性。這裡提供兩種安全的解決方案。分別來進行講解:
- 使用-l參數設置為隻有本地可以連接:這種方式,就隻能通過本機才能連接,別的機器都不能訪問,可以達到最好的安全性。
- 使用防火墻,關閉11211端口,外面也不能訪問。
ufw enable # 開啟防火墻 ufw disable # 關閉防火墻 ufw default deny # 防火墻以禁止的方式打開,默認是關閉那些沒有開啟的端口 ufw deny 端口號 # 關閉某個端口 ufw allow 端口號 # 開啟某個端口
在Django中使用memcached:
首先需要在settings.py中配置好緩存:
CACHES = { 'default': { 'BACKEND': 'django.core.cache.backends.memcached.MemcachedCache', 'LOCATION': '127.0.0.1:11211', } }
如果想要使用多臺機器,那麼可以在LOCATION指定多個連接,示例代碼如下:
CACHES = { 'default': { 'BACKEND': 'django.core.cache.backends.memcached.MemcachedCache', 'LOCATION': [ '172.19.26.240:11211', '172.19.26.242:11211', ] } }
配置好memcached的緩存後,以後在代碼中就可以使用以下代碼來操作memcached瞭:
from django.core.cache import cache def index(request): cache.set('abc','zhiliao',60) print(cache.get('abc')) response = HttpResponse('index') return response
需要註意的是,django在存儲數據到memcached中的時候,不會將指定的key存儲進去,而是會對key進行一些處理。比如會加一個前綴,會加一個版本號。如果想要自己加前綴,那麼可以在settings.CACHES中添加KEY_FUNCTION參數:
CACHES = { 'default': { 'BACKEND': 'django.core.cache.backends.memcached.MemcachedCache', 'LOCATION': '127.0.0.1:11211', 'KEY_FUNCTION': lambda key,prefix_key,version:"django:%s"%key } }
以上就是django中使用memcached示例詳解的詳細內容,更多關於django使用memcached的資料請關註WalkonNet其它相關文章!
推薦閱讀:
- php memcached的實例用法詳解
- django redis的使用方法詳解
- Django使用Redis進行緩存詳細步驟
- java中Memcached的使用實例(包括與Spring整合)
- Python的Web框架Django介紹與安裝方法