Redis 实战缓存

本篇概要:

  • [1. 设置、查询、获取过期时间;](#1. 设置、查询、获取过期时间;)
  • [2. 缓存穿透:设置空键;](#2. 缓存穿透:设置空键;)
  • [3. 封杀单ip;](#3. 封杀单ip;)
  • [4. 封杀ip段;](#4. 封杀ip段;)
  • [5. 缓存预热;](#5. 缓存预热;)
  • [6. 使用 hash 数据类型保存新闻的缓存,增加点击量;](#6. 使用 hash 数据类型保存新闻的缓存,增加点击量;)
  • [7. Sorted set(有序集合) 分离新闻缓存内容和新闻点击量、排行榜、预热新闻;](#7. Sorted set(有序集合) 分离新闻缓存内容和新闻点击量、排行榜、预热新闻;)

1. 设置、查询、获取过期时间;

php 复制代码
set key value
get key 
ttl key

2. 缓存穿透:设置空键;

  • 先从redis取,没取到再数据库取,再没取到设置默认值
  • 如果是默认缓存,到一定次数不让再刷
php 复制代码
# 命令:
expire

3. 封杀单ip;

  • 对于单独ip,开辟一个 key value,key = 前缀 + ip

4. 封杀ip段;

  • list 类型,列表,可以塞入字符串,可以按顺序也可直接插入奥列表头部尾部
php 复制代码
# 从键头部插入
lpush key value
# 获取列表长度
llen

# 操作
lpush users hua
lpush users zhang
lrange users 0 -1
# 显示:
# 1 zhang
# 2 hua

# 尾部插入
# 删除:
del users
# 重新插入:
rpush users zhang
rpush users hua

lrange users 0 -1
# 显示:
# 1 zhang
# 2 hua
  • 实战:ip前三段,装入list。ip段数量到阈值,整段被禁止

5. 缓存预热;

php 复制代码
set users hua EX 200
ttl users

6. 使用 hash 数据类型保存新闻的缓存,增加点击量;

  • 当缓存拥有多个独立字段,且会发生变化时,单纯的string就不适合了
  • hash数据类型,常用于商品缓存
php 复制代码
# 基本命令:
# 设置值:(表 - 字段 - 值)
hset key field value 
# 取值:
hget key field

hset news101 news_id 101
hset news101 news_title testtitle

hget news101 news_id
hgetall news101

# 显示
# 1) "news_id"
# 2) "101"
# 3) "news_title"
# 4) "testtitle"

# 更新写法:
# 获取所有
hgetall key 
# 获取所以keys
hkeys key 
# 获取所有 vals
hvals keys 

hmset news102 news_id 102 news_title testtitle2
hmget news102 news_id news_title
# (初始没有 views 也会自增1)
hincrby news102 views 1

7. Sorted set(有序集合) 分离新闻缓存内容和新闻点击量、排行榜、预热新闻;

  • 之前还有个 set 类型
  • Sorted set 自带一个 score,适合排行榜
php 复制代码
zadd key score member

# 举例:
zadd news 19 news101:
# 理解为名为news(模块)这个集合,加入一个元素叫news101,score是19
# 一个系统模块很多,都要用单独的集合名称

# 如果2条新闻,保存点击量
zadd news 12 news101
zadd news 31 news102

# 查看 从第一条到最后一条
zrange news 0 -1 
# 取前三名:
zrange news 0 2
# 带分数查看
zrange news 0 -1 withscores 
# 查看排名(0 就是第一位)
zrank news 
# 倒序
zrevrange news 0 -1 with score 

# 给指定元素加分
# 返回加完之后的值,没有则新增
zincrby news 1 news101 

# 查询分数:
zscore news news101

# 排行榜的各种套路:
zrange news 0 -1

# 根据指定分数看排行榜:
zrangebyscore news 15 22
zrevrangebyscore news 22 15
# 以上加上score可以查看score
相关推荐
LSL666_3 分钟前
1 概述及简单登录(不涉及数据库)
数据库·servlet
q***06473 小时前
MySQL的UPDATE(更新数据)详解
数据库·mysql
8***B3 小时前
MySQL性能
数据库·mysql
q***72194 小时前
oracle使用PLSQL导出表数据
数据库·oracle
数据库生产实战4 小时前
Oracle DG备库日志切换解析,Private strand flush not complete如何理解?(基础知识)
数据库·oracle
百***75744 小时前
从 SQL 语句到数据库操作
数据库·sql·oracle
i***39584 小时前
SQL 注入详解:原理、危害与防范措施
数据库·sql·oracle
m***56725 小时前
Win10下安装 Redis
数据库·redis·缓存
Warren985 小时前
Python自动化测试全栈面试
服务器·网络·数据库·mysql·ubuntu·面试·职场和发展
闲人编程5 小时前
Python的导入系统:模块查找、加载和缓存机制
java·python·缓存·加载器·codecapsule·查找器