Django-32 Redis1

坑1:redis执行redis-service /etc/redis.conf卡死

解决:要把redis.conf配置里面的daemonize的no改成yes

配置文件路径:/etc/redis.conf
mysql配置文件:/etc/mysql/mysql.conf.d/mysqld.cnf

备份:cp redis.conf redis_bak.conf
修改备份文件的用户组为redis:chown redis:root redis_bak.conf

添加密码

  1. 修改redis.conf配置:500行左右:requirepass 密码
  2. 关闭redis
    /usr/bin/redis-cli shutdown
    or
    kill -9 PID
  3. 启动redis redis-server /etc/redis.conf
  4. 验证:redis-cli -a 密码
    ping 返回pong就是成功了。

远程连接

  1. 注释掉本地IP地址绑定
    69行: # bind 127.0.0.1 ::1
  2. 关闭保护模式(把yes改为no)
    88行:protected-mode no
  3. 重启redis服务
  4. 客户端连接试一下:redis-cli -h 10.0.8.10 -a 密码

命令介绍

  • select number
    切换数据库(redis默认有16个库,0-15位具体库的编号,默认进入的库的编号为0)

  • info
    查看信息

  • keys表达式
    查找所有符合给定模式的key
    KEYS * 匹配数据库中所有key
    KEYS h?llo 匹配hello,hallo等
    KEYS h*llo 匹配hllo和heeeeello等
    注:正式环境中,请勿使用此命令,由于redis单进程单线程当key很多时,当前命令会阻塞redis

  • type key
    返回key的数据类型

  • exists key
    当前key是否存在,1在0不在

  • del key
    删除key

  • rename key newkey
    改变key名字

  • flushdb
    清除所在库的所有数据库

  • flushall
    清除所有数据库数据

基础概念

1、字符串、数字,都会转为字符串来存储
2、以二进制的方式存储在内存中
注意:

  • key命名规范
    可采用 -wang:email
  • key命名规范
    1,key值不宜过长,消耗内存,且在数据中查找这类键值的计算成本高
    2,不宜过短,可读性差

  • 1,一个字符串类型的值最多能存512M内容

常用命令

  • set key value nx ex
    设置一个字符串的key
    nx:not exist 表示key不存在时,才存储这个key
    ex:expire 过期时间,单位s
  • strlen key
    获取key存储值的长度
  • getrange key start stop
    获取指定返回切片内容【包含start stop】
  • setrange key index value
    从索引值开始,用value替换原内容,返回最新长度
  • mset key1 value1 key2 value key3 value3
    批量添加key和value
  • mget key1 key2 key3
    批量获取key的值

数值操作

  • incrby key 步长
    将key增加指定步长
  • decrby key 步长
    将key减少指定步长
    incr key
    +1操作
    decr key
    -1 操作
  • incrbyfloat key step
    float类型

应用场景

缓存

mysql数据存储到redis字符串类型中

并发计数-点赞/秒杀

利用redis单进程单线程特点,并发问题转为串行问题

带有效期的验证码

借助过期时间,存放验证码;到期后自动消亡

过期时间

默认情况下,key没有过期时间,需要手动指定
方案1:直接用set的ex参数
set key value ex 3
方案2:使用expire通用命令
1,set key value
2,expire key 5 # 5秒
3,pexpire key 5 # 5毫秒

检查过期时间

  • ttl key - 通用命令
    返回值:
    -1:代表当前key,没有过期时间
    >0:代表当前key的剩余存活时间
    -2:代表当前key不存在
    删除过期时间 persist key(把带有过期时间的key变为永久不过期)
    返回值:
    1:删除成功
    0:没有过期时间或者key不存在

redis删除过期key机制

每个redis数据库中,都会有一个特殊容器负责存储带有过期时间的key以及它对应的过期时间,这个容器称为“过期字典”。
针对过期字典中的key,redis结合,惰性删除和定期删除两大机制,有效删除过期数据。

最大内存检查

最后一道保险 - maxmemory 配置选项
一旦内存量超过最大限制,redis会在执行命令时触发内存淘汰(需手动在redis.conf中激活maxmemory配置项)
主流淘汰机制如下:
默认(no-enviction):禁入大多数写命令
volatile-lru:从已设置过期时间的内存数据集中挑选最近最少使用的数据淘汰
volatile-ttl:从已设置过期时间的内存数据集中挑选即将过期的数据淘汰
volatile-random:从已设置过期时间的内存数据集中任意挑选数据淘汰
allkeys-lru:从内存数据集中挑选最近最少使用的数据 淘汰
allkeys-random:从数据集中任意挑选数据淘汰

数据类型-列表

1、 元素是字符串类型
2、列表头尾增值快,中间增删慢,增删元素是常态
3、元素可重复
4、最多可包含2^32-1个元素
5、索引同python列表

增加

  • lpush key value1 value2
    从列表头部压入元素
    返回list新的长度
  • rpush key value1 value2
    从列表尾部压入元素
    返回list新的长度
  • rpoplpush key1 key2
    从列表key1尾部弹出一个元素压入key2的头部
    返回被弹出的元素
  • linsert key after|before value newvalue
    在列表指定元素后/前插入元素
    返回:
    1,如果命令执行成功,返回列表长度
    2,如果没有找到pivot,返回-1
    3,如果key不存在或空列表,返回0

查看

  • lrange key start stop
    查看列表的元素
  • llen key
    获取列表长度

删除

  • lpop key
    从列表左边弹出一个元素

  • rpop key
    从列表右边弹出一个元素

  • blpop key timeout
    列表左边,阻塞弹出,列表为空时阻塞
    -brpop key timeout
    列表右边,阻塞弹出,列表为空时阻塞
    1, 如果弹出的列表不存在或为空,就会阻塞
    2,超过时间设置为0,就是永久阻塞,直到有数据可以弹出
    3,如果多个客户端阻塞再同一个列表上,使用first in first service原则,先到先服务

  • lrem key count value
    删除指定元素
    count>0:表示从头开始向尾搜索,移除与value相等的元素,数量为count
    count<0:表示从尾开始向头搜索,移除与value相等的元素,数量为count
    count=0:移除表中所有与value相等的值

  • ltrim key start stop
    保留指定范围内的元素
    场景:保存微博评论最后500条
    ltrim weibo:comments 0 499

更新

  • lset key index newvalue
    设置list指定索引的值

list应用场景

1,存储微博评论,做切割,只保留最新的xx个
2,生产者消费者模型,做中间层,存放生产者的任务

©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

友情链接更多精彩内容