• 使用 django-redis 作缓存


    1  缓存内容使用

    django支持多种不同的cache backend,默认使用的是localmem,django-redis 是一个使django支持 redis cache的功能组件。

    安装

    pip install django-redis

    注意,本人电脑在UBUNTU16.04下安装失败:

      原因分析:网络超时

      解决方法:

        手动下载django-redis包进行安装【安装时需要使用root用户】

        链接:https://pypi.org/project/django-redis/  进行下载安装

      

    在 project/settings.py 设置
    
    CACHES = { "default": { "BACKEND": "django_redis.cache.RedisCache", 
                  "LOCATION": "redis://127.0.0.1:6379/0",
                  "OPTIONS": { "CLIENT_CLASS": "django_redis.client.DefaultClient",
                          #有密码时需要加上密码连接
                          #"PASSWORD": "mysecret",  } } }

    LOCATION的写法是 redis://host:port/db

    db是redis的数据库序号,redis默认允许16个数据库,redis默认使用的是0。

    测试

    通过 python manage.py shell 进入交互命令

    >>> from django.core.cache import cache
    >>> cache.set('user', 'Aaron', 600) # 缓存有效时间为600秒,即10分钟 
     True 
    >>> cache.get('user') 
    'Aaron'

    我们再通过 /usr/local/bin/redis-cli 进入redis的交互命令

    127.0.0.1:6379> select 0 # 
      选择数据库0,默认也是0 OK
    127.0.0.1:6379> keys * # 显示所有的key 1)":1:user" # 刚刚在python shell里设置的key 
    127.0.0.1:6379> get :1:user # get(key)"x80x04x95 x00x00x00x00x00x00x00x8cx05Aaronx94." 
    127.0.0.1:6379>

    这时会发现之前在python shell里设置的key跟 redis-cli里显示的key有些不同。具体原因,可以参考这里

       用django cache设置的redis key的名字前加的序号有什么意义?

      而当我们在redis-cli交互命令窗口里 get key 的时候,返回是bytes类型,这是因为django-redis使用pickle将数据进行了序列化。

    #另外一种方法和上面的方法也相差不多
    settings.py中配置如下:
    
    #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中的是必须的,下面三条可有可无
    
    
    
    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的缓存

                                                                                                                                                                                                                                                                                                                                                     


    2 设置redis为缓存session服务器

    存储session

    • 使用存储会话的方式,可以使用settings.py的SESSION_ENGINE项指定
    • 基于数据库的会话:这是django默认的会话存储方式,需要添加django.contrib.sessions到的INSTALLED_APPS设置中,运行manage.py migrate在数据库中安装会话表,可显示指定为
    SESSION_ENGINE='django.contrib.sessions.backends.db'
    
    • 基于缓存的会话:只存在本地内在中,如果丢失则不能找回,比数据库的方式读写更快
    SESSION_ENGINE='django.contrib.sessions.backends.cache'
    
    • 可以将缓存和数据库同时使用:优先从本地缓存中获取,如果没有则从数据库中获取
    SESSION_ENGINE='django.contrib.sessions.backends.cached_db'

    会话过期时间

    • set_expiry(value):设置会话的超时时间
    • 如果没有指定,则两个星期后过期
    • 如果value是一个整数,会话将在values秒没有活动后过期
    • 若果value是一个imedelta对象,会话将在当前时间加上这个指定的日期/时间过期
    • 如果value为0,那么用户会话的Cookie将在用户的浏览器关闭时过期
    • 如果value为None,那么会话永不过期
    • 修改视图中login_handle函数,查看效果
    def login_handle(request):
        request.session['uname'] = request.POST['uname']
        # request.session.set_expiry(10)
        # request.session.set_expiry(timedelta(days=5))
        # request.session.set_expiry(0)
        # request.session.set_expiry(None)
        return redirect(reverse('main:index'))

    使用Redis缓存session

    • 会话还支持文件、纯cookie、Memcached、Redis等方式存储,下面演示使用redis存储
    • 安装包
    pip install django-redis-sessions
    
    • 修改settings中的配置,增加如下项
    SESSION_ENGINE = 'redis_sessions.session'
    SESSION_REDIS_HOST = 'localhost'
    SESSION_REDIS_PORT = 6379
    SESSION_REDIS_DB = 0
    SESSION_REDIS_PASSWORD = ''
    SESSION_REDIS_PREFIX = 'session'
    
    • 管理redis的命令
    启动:sudo redis-server /etc/redis/redis.conf
    停止:sudo redis-server stop
    重启:sudo redis-server restart
    redis-cli:使用客户端连接服务器
    keys *:查看所有的键
    get name:获取指定键的值
    del name:删除指定名称的键
  • 相关阅读:
    linux一键安装filemanager和caddy
    搭建owncloud
    Linux下解压命令大全
    linux虚拟机调整分辨率
    [Javascript] ==与===区别
    [转]ActiveX控件安全初始化之一:实现ISafeObject接口
    C# 温故而知新:Stream篇(—)
    [转]C# 温故而知新:Stream篇(二)
    【转】C# 温故而知新:Stream篇(三)
    [转]在企业应用开发中遵循开源协议
  • 原文地址:https://www.cnblogs.com/Skyda/p/9661707.html
Copyright © 2020-2023  润新知