主頁 > 知識庫 > Django項目如何配置Memcached和Redis緩存?選擇哪個更有優(yōu)勢?

Django項目如何配置Memcached和Redis緩存?選擇哪個更有優(yōu)勢?

熱門標(biāo)簽:看懂地圖標(biāo)注方法 蘇州人工外呼系統(tǒng)軟件 京華圖書館地圖標(biāo)注 淮安呼叫中心外呼系統(tǒng)如何 廣東旅游地圖標(biāo)注 佛山通用400電話申請 打印谷歌地圖標(biāo)注 電話機器人貸款詐騙 電話外呼系統(tǒng)招商代理

對于中大型網(wǎng)站而言,使用緩存減少對數(shù)據(jù)庫的訪問次數(shù)是提升網(wǎng)站性能的關(guān)鍵手段之一。在Django項目生產(chǎn)環(huán)境中最常用的緩存后臺是Memcached和Redis。今天小編就手把手教你如何在Django項目中配置Memcached和Redis作為緩存后臺。那么它們兩個到底哪個更好呢? 本文會對比這兩個存儲系統(tǒng)并在文末給出答案。

Memcache緩存

Memcache是一個高性能的分布式內(nèi)存對象緩存系統(tǒng),是Django原生支持的最快最有效的緩存系統(tǒng)。Memcached的優(yōu)點是速度快,屬于分布式緩存,支持同時在多臺服務(wù)器上運行 (Django會把它們當(dāng)成一個大緩存)。

第一步:安裝Memcached

windows系統(tǒng):官網(wǎng)下載,解壓安裝即可。

Linux系統(tǒng):Ubuntu系統(tǒng)需要使用sudo apt-get install libevent ibevent-dev安裝Memcached依賴環(huán)境,再使用sudo apt-get install memcached安裝memcached。

第二步:啟動Memcached

# Linux系統(tǒng)-前臺啟動
/usr/local/memcached/bin/memcached -p 11211 -m 64m -vv
# Linux系統(tǒng)-作為后臺服務(wù)啟動
/usr/local/memcached/bin/memcached -p 11211 -m 64m -d

第三步:pip安裝python-memcached

Python操作memcached數(shù)據(jù)庫需要安裝python-memcached或pylibmc, 推薦前者。

pip install pyhon-memcached

第四步:將memcached設(shè)為Django緩存后臺

# 本地緩存,使用localhost
CACHES = {
 'default': {
  'BACKEND': 'django.core.cache.backends.memcached.MemcachedCache',
  'LOCATION': '127.0.0.1:11211',
 }
}

# 使用unix soket通信
CACHES = {
 'default': {
  'BACKEND': 'django.core.cache.backends.memcached.MemcachedCache',
  'LOCATION': 'unix:/tmp/memcached.sock',
 }
} 

# 分布式緩存,多臺服務(wù)器,支持配置權(quán)重。
CACHES = {
 'default': {
  'BACKEND': 'django.core.cache.backends.memcached.MemcachedCache',
  'LOCATION': [
   '172.19.26.240:11211',
   '172.19.26.242:11211',
  ]
  # 我們也可以給緩存機器加權(quán)重,權(quán)重高的承擔(dān)更多的請求,如下:
  'LOCATION': [
   ('172.19.26.240:11211',5),
   ('172.19.26.242:11211',1),
  ]
 }
 }

Redis緩存

Redis 是當(dāng)今速度最快的內(nèi)存型非關(guān)系型(NoSQL)型數(shù)據(jù)庫。Redis不僅僅支持簡單的key-value類型的數(shù)據(jù),同時還提供list,set,zset,hash等多種數(shù)據(jù)結(jié)構(gòu)的存儲。

第一步:安裝Redis

  • windows系統(tǒng):官網(wǎng)下載,解壓安裝即可, 記得勾上加入環(huán)境變量。
  • Linux系統(tǒng):Ubuntu系統(tǒng)可使用sudo apt-get install redis-server安裝。

第二步:啟動Redis服務(wù)

# Windows系統(tǒng):cmd進入redis安裝目錄,啟動redis服務(wù)
redis-server.exe redis.windows.conf

# Linux系統(tǒng):進入redis安裝目錄啟動redis服務(wù)
redis-server /etc/redis/redis.conf 

# 打開redis交互命令行,用于測試(可選)
redis-cli.exe -h 127.0.0.1 -p 6379 # windows系統(tǒng)下另打開一個窗口
redis-cli # linux系統(tǒng)

注意:默認(rèn)情況下,訪問Redis服務(wù)器是不需要密碼的,為了讓其他服務(wù)器使用同增加安全性我們建議設(shè)置Redis服務(wù)器的訪問密碼。

由于redis默認(rèn)綁定本機的,所以第一步取消該設(shè)置:

#編輯配置文件
sudo vim /etc/redis/redis.conf

用vim打開該配置文件后,注釋掉下面這行:

# bind 127.0.0.1

然后設(shè)置登錄密碼。由于配置文件較長,命令模式下輸入/requirepass foobared快速搜索該配置項:

#找到下面這一行并去除注釋,未修改之前:
#requirepass foobared

#修改成:
requirepass your_pwd #設(shè)置新的密碼

修改后使用redis-server restart重啟服務(wù)器使配置生效。以后從其它服務(wù)器訪問redis時攜帶你設(shè)置的密碼即可:

redis-cli -a your_pwd -h hostip

第三步:pip安裝django-redis

Redis安裝好并且啟動后,你還需要通過pip安裝django-redis才能在Django中操作redis數(shù)據(jù)庫。

pip install django-redis

第四步:將Redis設(shè)為Django緩存后臺

CACHES = {
 'default': {
  'BACKEND': 'django_redis.cache.RedisCache',
  'LOCATION': 'redis://your_host_ip:6379', # redis所在服務(wù)器或容器ip地址
  "OPTIONS": {
   "CLIENT_CLASS": "django_redis.client.DefaultClient",
    "PASSWORD": "your_pwd", # 你設(shè)置的密碼
  },
 },
}

你還可以在settings.py設(shè)置緩存默認(rèn)過期時間(非必須)。

REDIS_TIMEOUT=24*60*60
CUBES_REDIS_TIMEOUT=60*30
NEVER_REDIS_TIMEOUT=365*24*60*60

測試緩存是否設(shè)置成功

在你修改完settings.py中關(guān)于緩存的配置后,你一定想知道Django緩存是否設(shè)置成功。你可以輸入下面命令打開Python的命令交互窗口:

python manage.py shell

然后逐條輸入以下命令進行測試。如果無任何報錯,說明你緩存設(shè)置成功。

from django.core.cache import cache #引入緩存模塊

cache.set('k1', '555', 60*1) #寫入key為k1,值為555的緩存,有效期1分鐘
cache.has_key('k1')#判斷key為k1是否存在
cache.get('k1') #獲取key為k1的緩存結(jié)果

Memcached vs Redis

Memcached和Redis 兩者都是基于內(nèi)存的、鍵-值數(shù)據(jù)存儲系統(tǒng),速度都很快,而且支持分布式部署,然而兩者的區(qū)別也挺大的。

  • 數(shù)據(jù)結(jié)構(gòu):與memcached相比,Redis擁有更多的數(shù)據(jù)結(jié)構(gòu)(如list,set,zset,hash)并且支持豐富的數(shù)據(jù)操作。
  • 鍵值尺寸上限:Redis每個鍵值(value)的存儲尺寸上限高達(dá)512MB,而Memcached每個鍵值尺寸最大不超過1MB。
  • 數(shù)據(jù)持久化:Memcached不支持?jǐn)?shù)據(jù)持久化,服務(wù)器重啟后緩存數(shù)據(jù)就沒了,而Redis不僅支持支持緩存數(shù)據(jù)在硬盤上的持久化,還支持master-slave模式的數(shù)據(jù)備份。

從各方面看,Redis功能特性遠(yuǎn)優(yōu)于Memcached。如果你的企業(yè)要選緩存系統(tǒng),小編建議直接上redis就夠了。

以上就是Django項目如何配置Memcached和Redis緩存?選擇哪個更有優(yōu)勢?的詳細(xì)內(nèi)容,更多關(guān)于Django項目配置Memcached和Redis緩存的資料請關(guān)注腳本之家其它相關(guān)文章!

您可能感興趣的文章:
  • Django如何使用redis作為緩存
  • django框架用戶權(quán)限中的session緩存到redis中的方法
  • Django 緩存配置Redis使用詳解
  • Django使用redis緩存服務(wù)器的實現(xiàn)代碼示例
  • redis之django-redis的簡單緩存使用
  • Django使用redis配置緩存的方法

標(biāo)簽:畢節(jié) 駐馬店 江蘇 中山 呼和浩特 衡水 湖州 股票

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《Django項目如何配置Memcached和Redis緩存?選擇哪個更有優(yōu)勢?》,本文關(guān)鍵詞  Django,項目,如何,配置,Memcached,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《Django項目如何配置Memcached和Redis緩存?選擇哪個更有優(yōu)勢?》相關(guān)的同類信息!
  • 本頁收集關(guān)于Django項目如何配置Memcached和Redis緩存?選擇哪個更有優(yōu)勢?的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章