Redis简单介绍

一、前言:为什么 Redis 如此流行?

你可能听说过:

  • "高并发系统离不开 Redis"
  • "面试必问 Redis 缓存穿透、雪崩"
  • "Redis 能扛住百万 QPS"

但 Redis 到底是什么?它凭什么成为现代应用架构的"标配"?

本文将用最简洁的方式,带你:

✅ 理解 Redis 是什么、能做什么

✅ 掌握它的核心特性和五大基本数据类型

✅ 了解典型使用场景

✅ 避开常见认知误区


二、Redis 是什么?

Redis(Remote Dictionary Server) 是一个开源的、基于内存的 键值对(Key-Value)存储系统,常被用作:

  • 缓存
  • 消息队列
  • 分布式锁
  • 会话存储(Session Store)
  • 实时排行榜/计数器

📌 官方定义:
"Redis is an open source, in-memory data structure store, used as a database, cache, and message broker."

核心特点:

特性 说明
基于内存 数据存在 RAM 中,读写极快(微秒级)
持久化支持 可将内存数据异步写入磁盘(RDB / AOF)
单线程模型 6.0 之前为单线程,避免锁竞争,高吞吐
丰富的数据结构 不只是字符串,还支持 List、Set、ZSet、Hash 等
高可用 & 集群 支持主从复制、哨兵(Sentinel)、Cluster 集群

三、Redis 能做什么?典型应用场景

1. 缓存加速(最常见)

  • 将数据库查询结果缓存到 Redis
  • 下次请求直接读 Redis,避免查 DB
  • 示例:商品详情页、用户信息
python 复制代码
# 伪代码
user = redis.get("user:123")
if not user:
    user = db.query("SELECT * FROM users WHERE id=123")
    redis.setex("user:123", 3600, user)  # 缓存1小时

2. 分布式锁

  • 多个服务实例协调资源访问
  • 利用 SET key value NX EX 实现原子加锁

3. 限流与计数

  • 利用 INCR 实现接口调用次数统计
  • 结合过期时间实现滑动窗口限流

4. 排行榜 / Top N

  • 使用 Sorted Set(ZSet) 存储用户积分
  • ZREVRANGE 快速获取 Top 10

5. 消息队列(轻量级)

  • 使用 ListLPUSH + BRPOP 实现生产消费
  • (注:复杂场景建议用 Kafka/RabbitMQ)

四、Redis 的五大基本数据类型

Redis 不是简单的"key → string",它支持多种数据结构:

类型 结构 典型命令 应用场景
String 字符串 SET, GET, INCR 缓存、计数器
Hash 哈希表 HSET, HGET, HGETALL 存储对象(如用户信息)
List 列表(双向链表) LPUSH, RPOP, LRANGE 消息队列、最新消息列表
Set 无序集合(去重) SADD, SMEMBERS, SINTER 标签系统、共同好友
Sorted Set (ZSet) 有序集合(带分数) ZADD, ZRANGE, ZSCORE 排行榜、延迟任务

示例:用 Hash 存储用户信息

bash 复制代码
> HSET user:1001 name "张三" age 28 city "北京"
> HGET user:1001 name
"张三"
> HGETALL user:1001
1) "name"
2) "张三"
3) "age"
4) "28"
5) "city"
6) "北京"

五、Redis 为什么这么快?

很多人以为"因为它是内存数据库",但这只是部分原因。真正关键在于:

  1. 纯内存操作:避免磁盘 I/O 瓶颈
  2. 单线程 + I/O 多路复用 (epoll/kqueue)
    • 单线程避免上下文切换和锁竞争
    • 一个线程处理所有客户端请求,高效利用 CPU
  3. 高效的数据结构:底层针对每种类型优化(如 ZSet 用跳表)
  4. 非阻塞网络模型:高并发下仍保持低延迟

⚡ 性能数据:

在普通服务器上,Redis 可轻松达到 10万+ QPS ,高端机器甚至 百万 QPS


六、Redis 会丢数据吗?持久化机制

虽然 Redis 是内存数据库,但它提供两种持久化方式,防止重启后数据全丢:

1. RDB(快照)

  • 定时将内存数据全量保存为二进制文件(dump.rdb)
  • 优点:文件紧凑,恢复快
  • 缺点:可能丢失最后一次快照后的数据

2. AOF(Append Only File)

  • 记录每个写操作命令,重启时重放
  • 优点:数据更安全(可配置每秒/每次同步)
  • 缺点:文件大,恢复慢

✅ 生产环境建议:RDB + AOF 混合使用(Redis 4.0+ 支持)


七、常见误区澄清

❌ 误区 1:"Redis 只能做缓存"

事实:Redis 是功能完整的数据结构服务器,可作为主数据库(如社交 feed、实时分析)。

❌ 误区 2:"Redis 单线程所以不能利用多核"

事实:虽然核心逻辑单线程,但可通过部署多个实例或使用 Redis Cluster 横向扩展。

❌ 误区 3:"Redis 无限快,随便用"

事实 :大 Key、热 Key、不当使用 KEYS * 会导致性能骤降甚至阻塞。


八、如何开始使用 Redis?

  1. 安装 (以 Ubuntu 为例):

    bash 复制代码
    sudo apt update
    sudo apt install redis-server
    redis-cli ping  # 返回 PONG 表示成功
  2. 连接与操作

    bash 复制代码
    $ redis-cli
    127.0.0.1:6379> SET hello "world"
    OK
    127.0.0.1:6379> GET hello
    "world"
  3. 客户端库

    • Java:Lettuce、Jedis
    • Python:redis-py
    • Node.js:ioredis

九、结语

感谢您的阅读!如果你有任何疑问或想要分享的经验,请在评论区留言交流!

相关推荐
lifejump2 小时前
Pikachu | SQL-inject
数据库·sql
C-20022 小时前
Casdoor 容器部署并实现 JumpServer 对接 CAS
数据库
ChineHe2 小时前
Redis数据类型篇003_详解Lists列表类型及其命令
数据库·redis·缓存
AllData公司负责人2 小时前
AllData数据中台-数据同步平台集成开源项目Seatunnel-Web,完成Mysql到Doris同步流程
数据库·mysql·开源
自燃人~3 小时前
实战都通用的 Watchdog 原理说明
redis·面试
雪域迷影3 小时前
Python中连接Redis数据库并存储数据
redis·python
Mr.Entropy3 小时前
数据库读写分离介绍
数据库
Codeking__3 小时前
Redis的value类型及编码方式介绍——string
数据库·redis·缓存
ShuiShenHuoLe3 小时前
maven配置阿里源
java·数据库·maven