Django分别使用Memcached和Redis作为缓存的配置(Linux环境)
1 使用memcached
1.1 安装memcached
安装(Linux)
sudo apt install memcached
启动
#方式一:
service memcached start
# 方式二:
/usr/bin/memcached -u memcache -m 1024 -p 11222 -l 0.0.0.0 -d start
- -d:这个参数是让memcached在后台运行
- -m:指定占用多少内存。以M为单位,默认为64M。
- -p:指定占用的端口。默认端口是11211。
- -l:别的机器可以通过哪个ip地址连接到我这台服务器,如果想要让别的机器连接,就必须设置-l 0.0.0.0
检测启动成功
ps aux|grep memcached
# memcache 11025 0.0 0.1 326560 2372 ? Ssl Aug28 0:01 memcached -u memcache -m 512 -p 11211 -l 0.0.0.0 -d
1.2 Django连接memcached
1.2.1在'setting.py'文件中添加缓存的配置
# 缓存
CACHES = {
'default': {
'BACKEND': 'django.core.cache.backends.memcached.MemcachedCache',
'LOCATION': [
'172.19.26.240:11211',
'172.19.26.242:11211',
]
}
}
注意:添加的键的命名方式如下
def default_key_func(key, key_prefix, version):
return '%s:%s:%s' % (key_prefix, version, key)
如要修改,可在setting.py文件中添加配置'KEY_FUNCTION'
CACHES = {
'default': {
'BACKEND': 'django.core.cache.backends.memcached.MemcachedCache',
'LOCATION': '172.19.26.240:11211',
'KEY_FUNCTION': lambda: key_prefix,version,key : 'Django'+key,
}
}
1.2.2 配置好之后在views中操作cache:
from django.core.cache import cache
def index(request):
cache.set('username','django',60)
print(cache.get('username'))
return HttpResponse('index')
2 使用redis
2.1 安装redis
安装(Linux)
- 将下载的压缩文件解压
tar zxvf redis-4.0.8.tar.gz
- 复制:推荐放在"/usr/local/"下
mv -r redis-4.0.8/* /usr/local/redis
- 生成和安装
cd /usr/local/redis
make
make install
启动和配置
- 默认方式启动
redis-server
- 运行启动
redis-server --port 6380 # 指定运行的端口号
- 配置文件方式启动
redis-server /etc/redis/redis.conf
客户端连接redis
- 交互式方式
redis-cli -h {host} -p {port} # 会进入交互式环境
- 命令方式
redis-cli -h {host} -p {port} {command} # 直接执行一个命令,不进入交互式环境
停止redis服务
# 客户端关闭redis服务器,默认save即关闭时生成持久文件
redis-cli shutdown nosave|save
2.2 Django配置redis缓存
开发机上安装django-redis
pip install django-redis
配置文件'setting.py'
# 创建键时命名方式
def KEY_FUNCTION(key, key_prefix, version):
return "django:" + key
# redis缓存
CACHES = {
'default': {
'BACKEND': 'django_redis.cache.RedisCache',
# url格式 redis://[:password]@host:port/0
# 可以在url指定redis的密码,0表示低0个数据库
'LOCATION': 'redis://127.0.0.1:6379/1',
'OPTIONS': {
"CLIENT_CLASS": 'django_redis.client.DefaultClient',
'PASSWORD': '123456',
},
# 自定义键名命名规则
'KEY_FUNCTION': KEY_FUNCTION,
}
}
对view缓存
# 通过装饰器对views进行缓存
@cache_page(60 * 2) # 过期时间为秒
def cache(request):
return HttpResponse('cache')
对全站进行缓存,需在setting中设置
MIDDLEWARE = [
'django.middleware.cache.UpdateCacheMiddleware',
'django.middleware.common.CommonMiddleware',
'django.middleware.cache.FetchFromCacheMiddleware',
]
对模板片段进行缓存
{% load cache %}
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>首页</title>
</head>
<body>
{% cache 120 username %}
hello, Django
{% endcache %}
</body>
</html>
底层的缓存API
>>>from django.core.cache import cache
>>>cache.set('username', 'django', 120)
>>>True
>>>cache.get('username')
>>>'django'
>>>cache.ttl('username')
>>>101
>>>cache.set_many({'a': 1, 'b': 2, 'c': 3})
>>>cache.get_many(['a', 'b', 'c'])
>>>OrderedDict([('a', 1), ('b', 2), ('c', 3)])
redis服务器:
127.0.0.1:6379[1]> keys *
1) "django:b"
2) "django:c"
3) "django:a"
127.0.0.1:6379[1]>
Django分别使用Memcached和Redis作为缓存的配置(Linux环境)的更多相关文章
- java集成memcached、redis防止缓存穿透
下载相关jar,安装Memcached,安装教程:http://www.runoob.com/memcached/memcached-install.html spring配置memcached &l ...
- Redis+Spring缓存实例(windows环境,附实例源码及详解)
原文出处: 小宝鸽 一.Redis了解 1.1.Redis介绍: redis是一个key-value存储系统.和Memcached类似,它支持存储的value类型相对更多,包括string(字符串). ...
- 最新版redis的安装及配置 linux系统
1.redis下载 官网地址:https://redis.io/download 百度云地址:链接:http://pan.baidu.com/s/1c1Hu2gK 密码:h17z 2.解压 [root ...
- Redis总结(九)Linux环境如何安装redis
以前总结Redis 的一些基本的安装和使用,由于是测试方便,直接用的window 版的reids,并没有讲redis在linux下的安装.今天就补一下Linux环境如何安装redis. 大家可以这这里 ...
- Redis学习笔记一(Redis的详细安装及Linux环境变量配置和启动)
Redis Redis是一个开源的使用ANSI C语言编写.支持网络.可基于内存亦可持久化的日志型.Key-Value数据库,并提供多种语言的API. 我使用的是下面这个版本: 若没有资源的话,我在 ...
- redis的安装和启动linux环境
启动客户端连接redis服务,redis-cli -p(端口) -h(登录的服务的ip地址);不添加任何参数和选项直接使用redis-cli将会默认登录6379,默认使用ip 127.0.0.1#re ...
- redis(十六):Redis 安装,部署(LINUX环境下)
第一步:下载安装包 访问https://redis.io/download 到官网进行下载.这里下载最新的4.0版本. 第二步:安装 1.通过远程管理工具,将压缩包拷贝到Linux服务器中,执行解压 ...
- Django缓存系统选择之Memcached与Redis的区别与性能对比
Django支持使用Memcached和Redis这两种流行的内存型数据库作为缓存系统.我们今天来看Memcached和Redis的区别和性能对比. redis和memcached的区别 1.Redi ...
- Django使用Redis进行缓存详细最全流程
背景和意义服务器数据非经常更新.若每次都从硬盘读取一次,浪费服务器资源.拖慢响应速度.而且数据更新频率较高,服务器负担比较大.若保存到数据库,还需要额外建立一张对应的表存储数据.在Django中建立表 ...
随机推荐
- Daily Scrum1 11.3
今天是我们团队进入代码实现阶段的第一天,经过一周对上一届项目代码的阅读和研究,队员们已经从代码中分析出我们这次项目将要修改和补充的地方,我们接下来要做的地方就是在两周的时间内将团队项目在alpha阶段 ...
- 仿ArrayList功能的bag类
仿ArrayList功能的bag类 要想做到能够实现ArrayList功能,首先要有一个能往里填任何类型元素的的空间,但是不能用ArrayList来创建空间,这样这个项目就没有意义,因此,我创建了一个 ...
- C++:构造函数2——拷贝构造函数
前言:拷贝构造函数是C++中的重点之一,在这里对其知识进行一个简单的总结. 一.什么是拷贝构造函数 在C++中,对于内置类型的变量来说,在其创建的过程中用同类型的另一个变量来初始化它是完全可以的,如 ...
- ResNet笔记
参考: Deep Learning-TensorFlow (14) CNN卷积神经网络_深度残差网络 ResNet 先前的研究已经证明,拥有至少一个隐层的神经网络是一个通用的近似器,只要提高网络的深度 ...
- 如何解决abd.exe已停止工作
打开电脑,右键点击属性会出现如下界面: 点击左边高级系统设置:将会出现如下界面: 点击环境变量,点编辑. 把环境变量中的 ANDROID_ADB_SERVER_PORT 改成1122以后还遇到这个问 ...
- Python开发【第五篇】迭代器、生成器、递归函数、二分法
阅读目录 一.迭代器 1. 迭代的概念 #迭代器即迭代的工具(自定义的函数),那什么是迭代呢? #迭代:指一个重复的过程,每次重复都可以称之为一次迭代,并且每一次重复的结果是下一个迭代的初始值(例如: ...
- java中注解的使用与实例
1.spring中的一段代码: @Target(ElementType.PARAMETER)@Retention(RetentionPolicy.RUNTIME)@Documentedpublic @ ...
- Linux操作系统(二)
SSD工作原理:http://www.360doc.com/content/15/0318/15/16824943_456186965.shtml HHD工作原理:http://blog.csdn.n ...
- git常用命令复习及其基本使用示例
年后回来新上到项目,对于git的一些操作命令记得有点混乱了,所以特整理笔记如下: 一.git常用命令复习 查看当前分支:git branch (显示结果中带有*号的是当前分支)查看所有分支: git ...
- mac下面安装redis
本文只记录了在homebrew下面安装redis的过程,过程比较简单,作为自己以后翻阅用吧, 首先安装homebrew,打开终端,在终端下面允许下面的命令(不要用root用户): /usr/bin/r ...