news 2026/2/19 4:25:40

【Redis】从零开始掌握redis --- 认识redis

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
【Redis】从零开始掌握redis --- 认识redis

任何收获都不是偶然,
一点一滴的进步终会让未来的你焕然一新!

从零开始认识redis

  • 1 认识redis
  • 2 浅谈redis在分布式系统中的应用
  • 3 redis的特性

1 认识redis

redis的官方文档
redis文档中给了redis清晰的定位:

  • redis全程是Remote Dictionary Server(远程字典服务器),指明其储存的结构是“键值对”。
  • 作为非关系性数据集成(NoSql)中间件,用更快的速度、更多内存和更高的准确性构建程序。

NoSQL(Not Only SQL) 并不是否定 SQL,而是补充传统关系型数据库的一种新范式。

✅ NoSQL 特征:

特性SQL(关系型)NoSQL(非关系型)
数据结构结构化(Structured)非结构化(Unstructured)
数据关系强关联(主外键)无关联(嵌套/冗余存储)
查询语言SQL 标准语句每种数据库自定义
事务支持支持 ACID多数不支持 ACID,仅保证最终一致性
存储方式基于磁盘基于内存
扩展方式垂直扩展(升级硬件)水平扩展(多机分片)
使用场景安全性高、结构稳定、金融电商等海量数据、实时访问、性能敏感系统

特性对比无法感受到两种的差距,我们举个例子,比如现在我想要储存一个学生的基本信息,使用sql和redis分别进行实现:

createtablestudent(idint,namevarchar(20),ageint);insertintostudent(id,name,age)values(1,'张三',18);
# 1. 存储单个学生信息(Hash结构:键为student:1,字段为id、name、age,对应值分别为1、张三、18)HSET student:1id1name"张三"age18# 会得到一个数据{"id":1,"name":"张三","age":18}

进行查询时:

操作SQLRedis
查询用户信息SELECT * FROM student WHERE id=1get student :1

2 浅谈redis在分布式系统中的应用

单机架构简而言之就是只在一个服务器上提供的服务(内部可能使用了数据库,网络,等),一个服务器负责业务处理,也负责数据存储。

当业务进一步增长,数据量大大提升,一台主机难以支持时,就需要引入更多的主机,也就出现了分布式架构。
每台主机的硬件资源包括内存,cpu,硬盘,网络…服务器的每次请求都会消耗一定资源,同一时刻处理大量的请求就可能导致某个硬件资源不够用了,遇到资源不够的问题有两种主要解决思想:

  1. 开源:简单粗暴的解决,增加更多的硬件资源。一台主机扩展到极限了,就需要加入更多的主机了。引入多台主机就构成了分布式系统了。
  2. 节流:针对程序优化,优化数据结构,数据库存储结构等等…这就看程序员的个人能力了

注意:引入分布式,是万不得已的,系统的复杂度会大大提高,出现bug的概率越高。

最简单的分布式系统就是一个业务服务器+一个储存服务器。但是当请求量提升时,可能会出现一台业务服务器处理不过来的情况,这时可以在引入一台业务服务器,通过网关做负载均衡,他们共同读取一个数据库。
当当处理的请求量增加,导致数据库读写消耗增大时,可以将储存服务器也增添一个,设置一个主服务器和一个从属服务器,他们之间会进行数据同步:主服务器负责数据写操作,从服务器负责数据操作,主服务器会将写入的数据同步到读服务器中。

此时又出现了一个新问题,对于一个十分频繁且耗时的查询(比如查询全体成员成绩),每次查询会占用大量的资源。同时因为数据库的处理读取速度很慢,频繁的查询更会导致超时。这时就需要对热数据进行处理,引入缓存,将热数据储存到缓存中。当业务服务器处理请求时先在缓存服务器中查找,没有再去存储服务器中查询。当然这样也会引入很多的问题:

  1. 缓存数据应该保留多久?
  2. 数据库数据修改了导致和缓存中不一致了怎么办?

这个redis就是作为缓存服务器出现的。由于其储存是在内存中进行的,读写速度是比硬盘读写高好几个数量级的!这也是redis快速的重要原因:

操作类型Redis(单线程)MySQL(InnoDB 引擎)PostgreSQL
读 QPS(每秒查询数)10 万~100 万 +1 万~5 万(开启缓存)1 万~5 万
写 QPS(每秒写入数)5 万~50 万 +5000~2 万(开启缓存)5000~2 万
平均响应延迟微秒级(~100μs)毫秒级(~10ms)毫秒级

注意:redis的快速是相对来说的,比关系型数据库快,但还是比不过内存变量,毕竟redis说到底还是网络服务中间件,网络的延迟是不可避免的!

3 redis的特性

redis是一个在内存中储存数据的中间件,可以用于数据缓存,也可以用做数据库,通常是在分布式系统中发挥作用。

同时redis也会提供持久化的能力,因为内存数据一旦重启就会消失,所以在硬盘中储存一份是非常有必要的!并且redis是支持集群的(一个redis主机储存的数据是有限的,引入多个主机可以提供更好的能力)!

redis最重要的特性就是快,其快的原因:

  1. redis本质是使用内存进行存放数据的,读取数据相比于硬盘本身就高好几个数量级
  2. redis核心功能的实现简单,核心功能都是比较简单的操作内存的数据结构
  3. redis的网络使用IO多路复用(epoll),使用一个线程,基于事件触发构建的高效IO。
  4. redis使用的是单线程模型,减少了不必要的线程之间的竞争开销。通常:单线程不一定会提高速度,对于CPU密集型任务,使用多个线程可以充分使用CPU多核资源。但是对于redis来说,主要操作是操作内存的数据结构,并不会占用很多CPU资源(也就是单核和多核的区别不大)
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/2/14 3:00:32

GPT-5.2被Gemini 3 Pro碾压?真实编程场景实测,结果出人意料!

本文对比测试了GPT-5.2与Gemini 3 Pro在编程任务上的表现,通过烟花前端效果、学术论文分析和RAG代码重构三个场景进行评测。结果显示,Gemini 3 Pro在理解指令和代码重构方面表现更佳,而GPT-5.2在处理复杂任务时遇到困难。文章提示程序员在选择…

作者头像 李华
网站建设 2026/2/16 20:46:16

【收藏】大模型处理长文本的最佳实践:分步处理法

大模型处理长文本面临上下文窗口限制和处理能力下降的挑战。文章提出两种解决方案:多次生成后拼接完整报告,或分批处理数据后再总结。推荐采用分步骤处理方法,因其更符合人类操作习惯,也适应报告不同部分的不同需求。处理长文本时…

作者头像 李华
网站建设 2026/2/16 11:43:38

GTP协议

GTP协议 一、GTP协议 GTP(GPRS 隧道协议)是一种应用层协议,主要依赖 UDP、TCP,偶尔还有 SCTP,在 3G、4G 和 5G 等移动网络中传输数据包。它封装用户数据和信令,利用这些底层传输进行传输,但不提…

作者头像 李华
网站建设 2026/2/18 23:07:47

巴菲特的投资智慧与长期财富

巴菲特的投资智慧与长期财富关键词:巴菲特、投资智慧、长期财富、价值投资、复利效应摘要:本文深入探讨了巴菲特的投资智慧及其与长期财富积累之间的紧密联系。从巴菲特的投资理念、核心策略入手,详细剖析其背后的核心概念、算法原理以及数学…

作者头像 李华
网站建设 2026/2/17 15:51:58

海外的bug-hunters,不一样的403bypass

一种绕过403的新技术,跟大家分享一下。研究HTTP协议已经有一段时间了。发现HTTP协议的1.0版本可以绕过403。于是开始对lyncdiscover.microsoft.com域做FUZZ并且发现了几个403Forbidden的文件。(访问fsip.svc为403)在经过尝试后,得…

作者头像 李华
网站建设 2026/2/18 9:34:17

模型推理加速技术全景解析:从基础优化到前沿创新

在2024-2025年间,大模型推理加速技术取得了显著突破,从传统的模型压缩到前沿的分页内存管理,再到革命性的投机解码,这些技术共同推动了大模型推理速度的质的飞跃。本报告将深入浅出地解析这些主流加速手段,结合一年内发…

作者头像 李华