django中使用memcached示例詳解
什么是memcached:
- memcached之前是danga的一個項目,最早是為LiveJournal服務的,當初設計師為了加速LiveJournal訪問速度而開發(fā)的,后來被很多大型項目采用。官網(wǎng)是www.danga.com或者是memcached.org。
- Memcached是一個高性能的分布式的內(nèi)存對象緩存系統(tǒng),全世界有不少公司采用這個緩存項目來構(gòu)建大負載的網(wǎng)站,來分擔數(shù)據(jù)庫的壓力。Memcached是通過在內(nèi)存里維護一個統(tǒng)一的巨大的hash表,memcached能存儲各種各樣的數(shù)據(jù),包括圖像、視頻、文件、以及數(shù)據(jù)庫檢索的結(jié)果等。簡單的說就是將數(shù)據(jù)調(diào)用到內(nèi)存中,然后從內(nèi)存中讀取,從而大大提高讀取速度。
哪些情況下適合使用Memcached:存儲驗證碼(圖形驗證碼、短信驗證碼)、登錄session等所有不是至關(guān)重要的數(shù)據(jù)。
安裝和啟動memcached:
windows
安裝:memcached.exe -d install。
啟動:memcached.exe -d start。
linux(ubuntu)
安裝:sudo apt install memcached
啟動: cd /usr/local/memcached/bin ./memcached -d start
可能出現(xiàn)的問題:
提示你沒有權(quán)限:在打開cmd的時候,右鍵使用管理員身份運行。
提示缺少pthreadGC2.dll文件:將pthreadGC2.dll文件拷貝到windows/System32.
不要放在含有中文的路徑下面。
啟動memcached:
如果想要使用以上參數(shù)來指定一些配置信息,那么不能使用service memcached start,而應該使用/usr/bin/memcached的方式來運行。比如/usr/bin/memcached -u memcache -m 1024 -p 11222 start。
- -d:這個參數(shù)是讓memcached在后臺運行。
- -m:指定占用多少內(nèi)存。以M為單位,默認為64M。
- -p:指定占用的端口。默認端口是11211。
- -l:別的機器可以通過哪個ip地址連接到我這臺服務器。如果是通過service memcached start的方式,那么只能通過本機連接。如果想要讓別的機器連接,就必須設置-l 0.0.0.0。
telnet操作memcached:
telnet ip地址 [11211]
添加數(shù)據(jù):
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的區(qū)別:add是只負責添加數(shù)據(jù),不會去修改數(shù)據(jù)。如果添加的數(shù)據(jù)的key已經(jīng)存在了,則添加失敗,如果添加的key不存在,則添加成功。而set不同,如果memcached中不存在相同的key,則進行添加,如果存在,則替換。
獲取數(shù)據(jù):
語法: get key
示例: get username
刪除數(shù)據(jù):
語法: delete key
示例: delete username
flush_all:刪除memcached中的所有數(shù)據(jù)。
查看memcached的當前狀態(tài):
語法: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)
- 設置數(shù)據(jù): mc.set('username','hello world',time=60*5) mc.set_multi({'email':'xxx@qq.com','telphone':'111111'},time=60*5)
- 獲取數(shù)據(jù): mc.get('telphone')
- 刪除數(shù)據(jù): mc.delete('email')
- 自增長: mc.incr('read_count')
- 自減少: mc.decr('read_count')
memcached的安全性:
memcached的操作不需要任何用戶名和密碼,只需要知道m(xù)emcached服務器的ip地址和端口號即可。因此memcached使用的時候尤其要注意他的安全性。這里提供兩種安全的解決方案。分別來進行講解:
- 使用-l參數(shù)設置為只有本地可以連接:這種方式,就只能通過本機才能連接,別的機器都不能訪問,可以達到最好的安全性。
- 使用防火墻,關(guān)閉11211端口,外面也不能訪問。
ufw enable # 開啟防火墻 ufw disable # 關(guān)閉防火墻 ufw default deny # 防火墻以禁止的方式打開,默認是關(guān)閉那些沒有開啟的端口 ufw deny 端口號 # 關(guān)閉某個端口 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在存儲數(shù)據(jù)到memcached中的時候,不會將指定的key存儲進去,而是會對key進行一些處理。比如會加一個前綴,會加一個版本號。如果想要自己加前綴,那么可以在settings.CACHES中添加KEY_FUNCTION參數(shù):
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示例詳解的詳細內(nèi)容,更多關(guān)于django使用memcached的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
Python3 venv搭建輕量級虛擬環(huán)境的步驟(圖文)
這篇文章主要介紹了Python3 venv搭建輕量級虛擬環(huán)境的步驟(圖文),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2019-08-08詳解Python中最常用的10個內(nèi)置函數(shù)
Python作為一種多用途編程語言,擁有豐富的內(nèi)置函數(shù)庫,這些函數(shù)可以極大地提高開發(fā)效率,本文將介紹Python中最常用的10個內(nèi)置函數(shù),我們將深入了解每個函數(shù),并提供示例代碼以幫助您更好地理解它們,需要的朋友可以參考下2023-11-11