Linux C/C++ 学习日记(60):redis(一):基本介绍

注:该文用于个人学习记录和知识交流,如有不足,欢迎指点。

redis下载参考:配置(10):通过源码安装redis-CSDN博客

一、redis是什么?

Redis 是一款开源的、高性能的键值对(Key-Value)内存数据库 ,全称为 Remote Dictionary Server。它以内存作为主要存储介质,同时支持数据持久化到磁盘,兼具极高的读写性能和数据可靠性,并且原生支持多种复杂数据结构,是目前互联网领域最流行的中间件之一。

二、redis核心特点

这些特点是 Redis 被广泛应用的核心原因,也是区别于传统关系型数据库(如 MySQL)的关键:

  1. 超高读写性能数据存储在内存中,避免了磁盘 I/O 的性能瓶颈,单机 QPS(每秒查询次数)可达 10 万级以上。

  2. 是一个KV服务器,用户通过TCP连接修改和访问数据。

  3. 丰富的数据结构支持字符串(String)、哈希(Hash)、列表(List)、集合(Set)、有序集合(Sorted Set)、位图(Bitmap)、地理空间(Geo)等多种数据类型,能满足多样化业务需求。

  4. 数据持久化 提供两种持久化方案,避免内存数据丢失:

    RDB :定时将内存数据快照写入磁盘,适合备份和灾难恢复。
    AOF :记录所有写操作命令,重启时重放命令恢复数据,数据安全性更高。

  5. 原子操作所有单个命令都是原子性的,支持事务(批量命令执行)和 CAS(Compare And Set)操作,可解决并发数据一致性问题。

  6. 分布式能力支持主从复制、哨兵模式(高可用)、集群模式(分片扩容),可轻松构建分布式 Redis 系统。

  7. 其他功能支持过期时间、发布订阅、Lua 脚本、管道(Pipeline)等扩展功能。

三、Redis 的主要作用

  • 数据缓存将数据库中高频访问的数据缓存到 Redis,降低数据库压力,提升接口响应速度。
  • 分布式协调实现分布式锁、分布式计数器、分布式会话等功能,解决分布式系统中的并发和状态共享问题。
  • 临时数据存储存储短期有效数据,如验证码、临时 token、购物车数据等,利用过期时间自动清理无效数据。
  • 消息传递基于发布订阅(Pub/Sub)或列表(List)实现轻量级消息队列,适用于低延迟、低可靠性要求的场景。
  • 复杂计算支持基于有序集合实现排行榜、基于位图实现用户签到统计、基于地理空间实现附近的人等功能。

四、Redis 的应用场景

应用场景 实现方式 核心优势
高频数据缓存 缓存商品信息、用户信息、首页热点数据,设置合理过期时间 降低数据库负载,提升响应速度
分布式锁 基于 SETNX(SET If Not Exists)+ 过期时间实现 解决分布式系统中资源竞争问题(如秒杀、订单扣减)
会话存储 替代传统 Cookie 或服务器本地会话,将用户会话存入 Redis 支持分布式部署,避免会话丢失
计数器 / 限流器 基于 INCR/DECR 原子操作实现文章阅读量、接口限流 高性能,支持高并发计数
排行榜系统 基于有序集合(Sorted Set)实现实时榜单(如销量榜、积分榜) 支持快速排序和范围查询,可动态更新分值
购物车功能 基于哈希(Hash)存储用户购物车数据,Key 为用户 ID,Value 为商品 ID 和数量 读写高效,支持批量操作
消息队列 基于 List 的 LPUSH/RPOP 实现简单队列,或基于 Pub/Sub 实现广播 轻量级,部署成本低
地理位置服务 基于 Geo 数据类型实现 "附近的人""门店距离排序" 支持经纬度存储和距离计算
用户签到 / 活跃度统计 基于 Bitmap 存储用户每日签到状态,1 个字节可存储 8 天状态 极大节省内存空间

五、Redis 与传统数据库的核心区别

特性 Redis 传统关系型数据库(如 MySQL)
存储介质 内存为主,磁盘为辅(持久化) 磁盘为主
数据模型 键值对,支持多种数据结构 关系模型(表、行、列)
读写性能 极高(内存操作) 中等(磁盘 I/O 瓶颈)
事务支持 弱事务(不支持回滚) 强事务(ACID 特性)
适用场景 缓存、高频读写、临时数据、分布式协调 持久化存储、复杂查询、事务性业务
相关推荐
蒸蒸yyyyzwd5 小时前
cpp对象模型学习笔记1.1-2.8
java·笔记·学习
阿蒙Amon6 小时前
TypeScript学习-第7章:泛型(Generic)
javascript·学习·typescript
Hill_HUIL6 小时前
学习日志23-路由高级特性(静态路由)
网络·学习
今儿敲了吗6 小时前
鸿蒙开发第一章学习笔记
笔记·学习·鸿蒙
经年未远9 小时前
vue3中实现耳机和扬声器切换方案
javascript·学习·vue
Hill_HUIL9 小时前
学习日志22-静态路由
网络·学习
詩不诉卿10 小时前
zephyr学习之自定义外部module记录
学习
浮游本尊10 小时前
React 18.x 学习计划 - 第十三天:部署与DevOps实践
学习·react.js·状态模式
wdfk_prog11 小时前
[Linux]学习笔记系列 -- [drivers][dma]dmapool
linux·笔记·学习
电饭叔11 小时前
Tkinter Button 括号内的核心参数详解
python·学习