Redis -带过期时间的key 如何删除掉的?
在redis内部有个 过期字典,所有带过期时间的都有过期字典
默认情况下 redis每秒会进行着10次过期字典的扫描,在每一次扫描过程里,执行如下操作:
1,随机拿出20个key
2,删除第一步中已经过期的key
3,如果过期(删掉的)key 比例 超过 4分之一,就开始重复以上步骤,如果只有1个过期那就都不执行了
默认 25ms的 超时时间,避免卡死
内存即将满了 该怎么办?
redis的配置项--maxmemory - 我配4G
策略:1, noeviction 写服务拒绝(接受够4G就拒绝接受) -- 默认配置
2, volatile-lru 尝试淘汰设置了过期时间的key,lru算法[最少使用优先],如果设置了这个,只接受有过期时间的
3, allkeys-lru 尝试淘汰所有的key,lru算法
4, volatile-ttl 尝试淘汰设置过期时间的key,谁ttl大 删谁
列表数据类型(List)
1,只能是字符串类型
2,头尾增删快,中间增删慢
3,元素可重复
4,索引同python列表
列表的常用命令
1,从列表头部添加元素
左插:LPUSH KEY value1 value2
右插:RPUSH l2 a b c d
2,查元素
LRANGE l1 0 -1
3,删除---当元素清空时,list的key也对应被删除
9、列表头部,阻塞弹出,列表为空时阻塞BLPOP key timeout
10、列表尾部,阻塞弹出,列表为空时阻塞
BRPOP key timeout
list 经典场景 生产者消费者模型
查看库
pip3 freeze | gre额p 'redis'