Django使用Redis进行缓存详细步骤
2023-06-13 09:19:48 时间
1.背景和意义
Redis不支持Windows!在它官网写得很清楚。但是开发环境一般是Windows系统。为了方便开发和调试,需要在Windows中安装Redis。微软自己弄了Redis的Windows版本。打开https://github.com/MSOpenTech/redis/releases下载msi安装包。该版本是64位。安装msi过程中,有个选项是否加入系统环境变量,记得勾上。一路下一步,安装。完成之后打开cmd,输入redis-server命令查看是否可以使用。不可以则重启一下即可。直接输入redis-server命令使用的配置文件是安装目录下的redis.windows.conf文件。
若提示错误 “ConnectionError: Error 10061 connecting to None:6379”,可以如下操作,打开cmd输入如下命令:`redis-cli shutdown` ,再执行redis-server即可。
(2)在ubuntu下安装,针对部署
`sudo apt-get install redis-server` 2,Redis 访问控制 # 默认情况下,访问 Redis 服务器是不需要密码的,为了让其他服务器使用同时增加安全性我们需要设置 Redis 服务器的访问密码。设置访问密码为 yourpassword。
# 由于 redis 默认绑定本机的,所以第一步取消该设置:
`sudo vim /etc/redis/redis.conf`
# 用vim打开该配置文件,然后注释掉下面这行:
`# bind 127.0.0.1`
# 然后设置登录密码,用vim打开配置文件,配置文件较长,命令模式下输入`/requirepass foobared`快速搜索该配置项:
# 编辑配置文件
`sudo vim /etc/redis/redis.conf`
# 找到下面这一行并去除注释(可以搜索requirepass)
# requirepass foobared 未修改之前
# 修改之后
`requirepass 123456789` # 假设123456789是我的redis密码
# 修改后重启服务器使配置生效:
`sudo /etc/init.d/redis-server restart`
# 此时在登录redis,权限被控制
root@VM-60-191-ubuntu:~# redis-cli
127.0.0.1:6379 keys *
(error) NOAUTH Authentication required.
# 用密码登录,具有权限
root@VM-60-191-ubuntu:~# redis-cli -a 123456789
127.0.0.1:6379 keys *
1) key2
# 通过以下命令从另一台linux服务器访问redis, password替换为你的密码,host替换为要访问的服务器
`redis-cli -a password -h hostip`
# 数据库的数量是可以配置的,不知道数据库就是数据库0,默认情况下是16个。修改redis.conf下的databases指令:
`databases 64` 3,安装django-redis和settings配置 pip install django-redis
default : {
BACKEND : django_redis.cache.RedisCache ,
LOCATION : redis://your_host_ip:6379 ,
OPTIONS : {
CLIENT_CLASS : django_redis.client.DefaultClient ,
PASSWORD : yoursecret ,
},
},
}
cache.set( v , 555 , 60*60) # 写入key为v,值为555的缓存,有效期30分钟
cache.has_key( v ) # 判断key为v是否存在
cache.get( v ) # 获取key为v的缓存
我想要获取技术服务或软件
服务范围:MySQL、ORACLE、SQLSERVER、MongoDB、PostgreSQL 、程序问题
服务方式:远程服务、电话支持、现场服务,沟通指定方式服务
技术标签:数据恢复、安装配置、数据迁移、集群容灾、异常处理、其它问题
本站部分文章参考或来源于网络,如有侵权请联系站长。
数据库远程运维 Django使用Redis进行缓存详细步骤
服务器数据非经常更新。若每次都从硬盘读取一次,浪费服务器资源、拖慢响应速度。而且数据更新频率较高,服务器负担比较大。若保存到数据库,还需要额外建立一张对应的表存储数据。在Django中建立表通常做法是建立一个模型。看似简单,但是调试麻烦、开发时长久。为了进行服务器的加速,使用Redis进行缓存。
2.配置步骤如下 1,服务器端安装 redis (1)在Windows安装redis,方便测试Redis不支持Windows!在它官网写得很清楚。但是开发环境一般是Windows系统。为了方便开发和调试,需要在Windows中安装Redis。微软自己弄了Redis的Windows版本。打开https://github.com/MSOpenTech/redis/releases下载msi安装包。该版本是64位。安装msi过程中,有个选项是否加入系统环境变量,记得勾上。一路下一步,安装。完成之后打开cmd,输入redis-server命令查看是否可以使用。不可以则重启一下即可。直接输入redis-server命令使用的配置文件是安装目录下的redis.windows.conf文件。
若提示错误 “ConnectionError: Error 10061 connecting to None:6379”,可以如下操作,打开cmd输入如下命令:`redis-cli shutdown` ,再执行redis-server即可。
(2)在ubuntu下安装,针对部署
`sudo apt-get install redis-server` 2,Redis 访问控制 # 默认情况下,访问 Redis 服务器是不需要密码的,为了让其他服务器使用同时增加安全性我们需要设置 Redis 服务器的访问密码。设置访问密码为 yourpassword。
# 由于 redis 默认绑定本机的,所以第一步取消该设置:
`sudo vim /etc/redis/redis.conf`
# 用vim打开该配置文件,然后注释掉下面这行:
`# bind 127.0.0.1`
# 然后设置登录密码,用vim打开配置文件,配置文件较长,命令模式下输入`/requirepass foobared`快速搜索该配置项:
# 编辑配置文件
`sudo vim /etc/redis/redis.conf`
# 找到下面这一行并去除注释(可以搜索requirepass)
# requirepass foobared 未修改之前
# 修改之后
`requirepass 123456789` # 假设123456789是我的redis密码
# 修改后重启服务器使配置生效:
`sudo /etc/init.d/redis-server restart`
# 此时在登录redis,权限被控制
root@VM-60-191-ubuntu:~# redis-cli
127.0.0.1:6379 keys *
(error) NOAUTH Authentication required.
# 用密码登录,具有权限
root@VM-60-191-ubuntu:~# redis-cli -a 123456789
127.0.0.1:6379 keys *
1) key2
# 通过以下命令从另一台linux服务器访问redis, password替换为你的密码,host替换为要访问的服务器
`redis-cli -a password -h hostip`
# 数据库的数量是可以配置的,不知道数据库就是数据库0,默认情况下是16个。修改redis.conf下的databases指令:
`databases 64` 3,安装django-redis和settings配置 pip install django-redis
settings.py中加入以下内容,your_host_ip换成你的服务器地址, yoursecret换成你的服务器密码
CACHES = {default : {
BACKEND : django_redis.cache.RedisCache ,
LOCATION : redis://your_host_ip:6379 ,
OPTIONS : {
CLIENT_CLASS : django_redis.client.DefaultClient ,
PASSWORD : yoursecret ,
},
},
}
REDIS_TIMEOUT=7*24*60*60
CUBES_REDIS_TIMEOUT=60*60
NEVER_REDIS_TIMEOUT=365*24*60*60
# cache中的是必须的,下面三条可有可无(超时设置啥的)
为了测试看可否正常使用 redis , 进入django的后台命令模式:
python manage.py shell逐条输入如下命令测试:
from django.core.cache import cache # 引入缓存模块cache.set( v , 555 , 60*60) # 写入key为v,值为555的缓存,有效期30分钟
cache.has_key( v ) # 判断key为v是否存在
cache.get( v ) # 获取key为v的缓存
到此这篇关于Django使用Redis进行缓存详细流程的文章就介绍到这了,更多相关Django Redis 缓存内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!
我想要获取技术服务或软件
服务范围:MySQL、ORACLE、SQLSERVER、MongoDB、PostgreSQL 、程序问题
服务方式:远程服务、电话支持、现场服务,沟通指定方式服务
技术标签:数据恢复、安装配置、数据迁移、集群容灾、异常处理、其它问题
本站部分文章参考或来源于网络,如有侵权请联系站长。
数据库远程运维 Django使用Redis进行缓存详细步骤
相关文章
- Java轻松处理Redis缓存(java处理redis)
- C语言怎么访问Redis?(c访问redis)
- 缓存如何快速清理Redis缓存(怎么清除redis)
- 里如何将数据库表存入Redis缓存中(怎么把表放到redis)
- 教你步步安装Redis客户端(怎么安装redis客户端)
- 缓存存取受阻应用无法访问Redis(应用不能访问redis)
- Redis缓存提升版本的进步(缓存 版本 redis)
- 改变动力 Redis 缓存技术(缓存了redis)
- 解决使用Redis缓存解决难题(缓存redis 问题)
- 更好Ann 比Redis更快更好的解决方案(比redis更快ann)
- 查看Redis究竟占用了多少缓存空间(查看redis占用缓存)
- 本地文件数据迁移到Redis存储(本地文件存到redis)
- 清理Redis缓存出错,需立即解决(清理redis缓存报错)
- 简单实现使用 Redis 存储数据字典(数据字典缓存redis)
- 极简Redis指南一本帮助你完全掌握Redis的书(推荐redis 书)
- Yum安装Redis最快速的安装体验(yum redis 下载)
- 拓展 破解tp50中Redis的使用困境使用TP50安装Redis拓展,克服Redis使用困境(tp5.0安装redis)
- 极速优化内存缓存与Redis缓存比较(内存缓存与redis缓存)
- 如何查找Redis目录实用技巧与指南(如何查找redis目录)
- 掌握 Redis 进行简单缓存管理(如何实现简化版redis)
- 合理运用Redis构建高效缓存系统(合理设计redis缓存)
- 理解Redis高级工具类封装(redis高级工具类封装)
- 构建基于Redis集群的高可用架构模式(redis集群架构模式)
- 红色天空Redis集群的优势(redis集群有啥好处)
- 快速部署Redis集群,实现最佳可用性(redis集群如何部署)
- 使用Redis实现阻塞队列限流(redis阻塞队列限流)
- Redis缓存技术有效规避缓存穿透问题(redis 避免缓存穿透)
- 精彩回放利用Redis实现缓存的效率提升(redis进行缓存的实现)
- 读写性能Redis集群中单数台机器的读写性能提升(redis集群单数台)