redis在Django当中的使用方法

发布于:2024-08-08 ⋅ 阅读:(97) ⋅ 点赞:(0)

redis在Django中怎么使用

  • 在utils/redis_pool.py文件 创建

import redis

POOL = redis.ConnectionPool(max_connections=10, decode_responses=True)
  • 在哪里用,导入用即可

from utils.redis_pool import POOL
import redis


# ---------------------
class pooltestView(APIView):
    def get(self, request, *args, **kwargs):
        conn = redis.Redis(connection_pool=POOL)
        # 统计有多少次数
        conn.incrby('age')

        res = conn.get('age')
        return APIResponse(msg=f'接口被访问了多少次!!')

image-20240515234136485

方式一:通用方式

######## 写个pool.py
import redis
POOL = redis.ConnectionPool(max_connections=10, decode_responses=True)
###### 在哪里用,导入用即可
from utils.pool import POOL
import redis
class RedisView(ViewSet):
    def list(self, request):
        conn = redis.Redis(connection_pool=POOL)
        conn.incrby('count')
        count = conn.get('count')
        return APIResponse(msg='您是第%s个访问的' % count)

方式二:django-redis

  • 在dev.py

#1  安装
pip install django-redis

# 2 配置文件配置
CACHES = {
    "default": {
        "BACKEND": "django_redis.cache.RedisCache",
        "LOCATION": "redis://127.0.0.1:6379",
        "OPTIONS": {
            "CLIENT_CLASS": "django_redis.client.DefaultClient",
            "CONNECTION_POOL_KWARGS": {"max_connections": 100}
            # "PASSWORD": "123",
        }
    }
}

# 3 在使用的位置
from django_redis import get_redis_connection
# ---------------------
class pooltestView(APIView):
    def get(self, request, *args, **kwargs):
        conn = get_redis_connection()
        # 统计有多少次数
        conn.incrby('age')

        res = conn.get('age')
        return APIResponse(msg=f'接口被访问了多少次!!')

方式三:django的缓存

# django内置的,可以直接操作缓存---》缓存的位置--》内存--》只要项目一重启,数据就没了
# 后期,我们要把缓存数据,放到 redis中 ,redis可以持久化,项目停止,但redis还运行,数据就不会丢

# 只要在配置文件中,如下配置,以后只要使用 cache.set  和 cache.get 通过都是去redis设置和取
CACHES = {
    "default": {
        "BACKEND": "django_redis.cache.RedisCache",
        "LOCATION": "redis://127.0.0.1:6379",
        "OPTIONS": {
            "CLIENT_CLASS": "django_redis.client.DefaultClient",
            "CONNECTION_POOL_KWARGS": {"max_connections": 100}
            # "PASSWORD": "123",
        }
    }
}

# cache.set()  设置缓存
# cache.get()  获取缓存




## 以后再django中,可以直接使用
cache.set 和cache.get  操作redis,用它错缓存 ---》非常简单

## 重点:
	-优势:redis 分数据类型, 只能设置5种数据类型
   	-django的缓存来讲 ,不限制类型,可以放python的任意类型
    
    -django的缓存来讲,cache.set('redis的key','不区分类型:放python的任意类型')  # person
    -cache.get('userinfo')
    -django cache 底层是基于: 把你存储的类型---》使用pickle序列化--bytes格式---》当redis的字符串形式存到redis中
    
    
    -以后咱们做redis的操作,可以直接使用django的缓存, 不需要考虑类型

网站公告

今日签到

点亮在社区的每一天
去签到