[ Redis ] | 初识Redis

目录

官方定义:

用于内存中存储数据

用于作为数据库

用于作为缓存

用于流式引擎和消息中间件

小结:


官方定义:

Redis 官网链接:Redis - The Real-time Data Platform

Redis官方对Redis的定义:开源的,在内存中存储,被数以百万计的开发者作为:数据库,缓存,流式引擎和消息中间件。... ... 存储数据,在内存中存储数据


用于内存中存储数据

这里最重要的就是在内存中存储,说到内存中存储,我们能想到我们在内存中定义一个变量。所以说:Redis只有在分布式系统中,才能发挥威力,如果只是单机的程序,直接通过变量存储数据的方式,比Redis更优。

在分布式系统中,必然有多个进程,并且是在不同主机上的多个进程。那么也就必然涉及到进程间通信,使用网络的进程间通信。

Redis就是基于网络,可以把自己内存中的变量给别的进程,甚至别的主机的进程使用


用于作为数据库

再说说数据库,现在的数据库用的比较多的还是MySQL,但是MySQL的缺点是:访问速度慢。俗话说:天下武功,唯快不破。很多互联网产品对于性能要求还是很高的。将Redis作为数据库访问,就很快~,(Redis + MySQL 才是正解... 下面说)毕竟操作内存的效率是要比操作磁盘要快个10万倍不止的~。(MySQL因为要支持数据约束等功能,在一次数据库访问会进行多次IO,这就导致本不富裕的性能,更加的雪上加霜了~)。

Redis相比于MySQL的劣势:存储空间很有限。


用于作为缓存

正解:又快又大,让Redis作为MySQL的cache,将热点数据在Redis中存储,将全量数据在MySQL中存储。这种方案的劣势:系统的复杂度提升,并且要解决Redis和MySQL之间的数据同步问题。

**"计算机世界中,没有银弹。"**总要付出一定的代价。


用于流式引擎和消息中间件

Redis公司的初心:作为消息中间件的消息队列,分布式系统下的生产者消费者模型。但是无心插柳柳成荫,有心栽花花不开。大家发现,作为缓存,作为数据库,还是更香一点~。


小结:

所以在Redis中,分布式系统的非常重要的一个问题,我们后期再谈。

相关推荐
Databend7 小时前
在 AWS 中国峰会逛了一天,我在 Databend 展台看到了 Agent 数据基础设施的新思路
数据库·人工智能·agent
犯困蛋挞yy8 小时前
用Claude快速解决Redis代码报错反复无解的问题
redis
小七-七牛开发者1 天前
TokenPilot:让 LLM Agent 长会话成本降 60%+ 的上下文管理
缓存·agent·token·context·上下文·推理成本
ClouGence1 天前
Oracle 数据同步为什么会出现数据不一致?长事务是常被忽略的原因
数据库·后端·oracle
飞将2 天前
从零实现数据库(2)——HashIndex + IndexManager
数据库
Nturmoils2 天前
订单列表慢查询,先看 WHERE、ORDER BY 和 LIMIT
数据库
渣波3 天前
拒绝 SQL 焦虑!手把手带你用 NestJS + Prisma + DTO 写出“防弹”级后端代码
javascript·数据库·后端
倔强的石头_4 天前
KingbaseES 新版MySQL 兼容版体验:旧版迁移 + 功能实测
数据库
用户3169353811836 天前
Java连接Redis
redis
倔强的石头_7 天前
《Kingbase护城河》——数据库存储空间全景探测与精细化瘦身实战
数据库