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
相关推荐
GZ_TOGOGO2 分钟前
Oracle数据库考试适合哪些人
数据库·oracle·数据库开发·ocp认证·2026年it学习
Gauss松鼠会3 分钟前
【openGauss】学习 gsql 命令行的使用
数据库·sql·database·opengauss
晓13137 分钟前
第二章:Redis常见命令与Java客户端
java·数据库·redis
·云扬·17 分钟前
MySQL索引实战指南:添加场景、联合索引要点与失效场景解析
数据库·mysql
填满你的记忆28 分钟前
【从零开始——Redis 进化日志|Day7】双写一致性难题:数据库与缓存如何不再“打架”?(附 Canal/读写锁实战)
java·数据库·redis·缓存·面试
小白考证进阶中28 分钟前
MySQL OCP认证可以考中文?备考难度怎么样?
数据库·mysql·dba·数据库管理·开闭原则·数据库管理员·mysql认证
蒟蒻的贤42 分钟前
操作系统复习
java·开发语言·数据库
Dontla1 小时前
打开网站时弹出Accept Cookies(接受Cookie)提示是什么意思?(数据保护法规,欧盟GDPR)
前端·数据库
赵八斤1 小时前
java 项目中配置多个数据源
java·开发语言·数据库
小冷coding1 小时前
【Java】以 Java + Redis + MySQL 为技术栈,模拟电商商品详情的读写场景,Cache Aside+ 延迟双删 方案
java·redis·mysql