前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >如何使用Memcached实现Django项目缓存

如何使用Memcached实现Django项目缓存

作者头像
极简小课
发布2022-06-21 18:25:37
1.4K0
发布2022-06-21 18:25:37
举报
文章被收录于专栏:极简小课极简小课

1. 安装memcached

这里以Centos下如何安装安装为例,运行如下命令,安装memcached

代码语言:javascript
复制
sudo yum install memcached

测试是否安装成功

代码语言:javascript
复制
memcached -help

如果没有报错,就表示安装成功了

2. 运行memcached

代码语言:javascript
复制
memcached -d -m 64 -l 127.0.0.1 -p 11211 -u root

-d:表示后台启动守护进程

-m: 表示使用多大内存,这里使用64M

-l:是监听的服务器IP地址,这里我们填本地,如果想让其他机器访问,写成0.0.0.0

-p:是端口号, 默认是11211

-u:指定用哪个用户来运行,这里指定root

查看memcached是否运行成功,使用如下命令

代码语言:javascript
复制
ps -ef|grep memcached

如果显示如下图,表示启动成功

可以使用如下命令关掉memcached进程

代码语言:javascript
复制
killall -9 memcached

3. 连接Memcached

使用telnet去连接,先安装telnet,如下命令

代码语言:javascript
复制
sudo yum install telnet

安装完成后,使用下面的命令连接memcached

代码语言:javascript
复制
telnet 127.0.0.1 11211

出现如下界面,表示连接成功,运行quit退出连接

至此,我们成功安装了memcached,并能成功运行,下面介绍Django项目如何去使用它

4. 安装python-mamcached

在自己的项目python环境下安装,如果是虚拟化经,要先运行虚拟环境再安装,命令如下

代码语言:javascript
复制
pip install python-memcached

5. 配置Django项目

在我们项目的setting.py文件里面,加入CACHE选项,如下

代码语言:javascript
复制
CACHES = {
    'default': {
        'BACKEND': 'django.core.cache.backends.memcached.MemcachedCache',
        'LOCATION': '127.0.0.1:11211',
    }
}

然后根据自己项目的实际情况,设置需要的缓存时间,我的个人Blog缓存时间设置为一天,即60*60*24秒

代码语言:javascript
复制
CACHE_MIDDLEWARE_SECONDS=60*60*24

最后,我们在中间件MIDDLEWARE添加memcached所需Django中间件,由于我选择的是缓存全站,所以需要的东西如下:注意中间件的位置和顺序

代码语言:javascript
复制
'django.middleware.cache.UpdateCacheMiddleware',# 放到中间件第一个位置
 ...... # 其他中间件
'django.middleware.cache.FetchFromCacheMiddleware',#放在中间件的最后位置

以上就是我们的全部配置和安装,重启nginx和uwsgi之后你就可以打开网站测速了,第一次打开的时候可能会比较慢,因为此时刚刚把你请求的东西放到缓存中,当你再次打开,或者说在你刚刚设定的缓存时间内打开,都是秒开的。

6. 注意事项

因为我们设置了24小时缓存,所以在缓存期间内,如果你写了一篇博客文章,你的网站不会立马显示出来,等到缓存时间过期,才会更新出来,如果你想立马显示出来,需要手动去清理下缓存,是缓存过期,网站就会重新丛数据库获取数据,手动是缓存过期,使用如下命令

代码语言:javascript
复制
# 先连接memcached
telnet 127.0.0.1 11211

#清除缓存
flush_all
本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2020-05-06,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 极简小课 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 3. 连接Memcached
  • 4. 安装python-mamcached
  • 5. 配置Django项目
  • 6. 注意事项
相关产品与服务
消息队列 TDMQ
消息队列 TDMQ (Tencent Distributed Message Queue)是腾讯基于 Apache Pulsar 自研的一个云原生消息中间件系列,其中包含兼容Pulsar、RabbitMQ、RocketMQ 等协议的消息队列子产品,得益于其底层计算与存储分离的架构,TDMQ 具备良好的弹性伸缩以及故障恢复能力。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档