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 特性)
适用场景 缓存、高频读写、临时数据、分布式协调 持久化存储、复杂查询、事务性业务
相关推荐
却道天凉_好个秋11 小时前
音视频学习(九十七):自适应码率(ABR)
学习·音视频·abr
red_redemption11 小时前
自由学习记录(142)
学习
لا معنى له11 小时前
JEPA:联合嵌入预测架构介绍 ——学习笔记
笔记·学习
阳光永恒73611 小时前
Python零基础入门全套资料包免费分享 | 从0到1系统学习路线(含课件+源码+实战案例)
开发语言·python·学习·编程入门·python教程·编程学习·免费资料
weixin_4588726111 小时前
东华复试OJ二刷复盘15
学习
却道天凉_好个秋11 小时前
音视频学习(九十六):PLC
学习·音视频·plc
知识分享小能手12 小时前
Redis入门学习教程,从入门到精通,Redis集群架构:语法知识点、使用方法与综合案例(6)
redis·学习·架构
xian_wwq12 小时前
【学习笔记】数据投毒的9种攻击方法与防御措施
笔记·学习·数据投毒
醇氧12 小时前
第一、二、三范式学习
数据库·学习·oracle
苦瓜小生14 小时前
【黑马点评学习笔记 | 实战篇 】| 10-用户签到+UV统计
笔记·后端·学习