[ 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中,分布式系统的非常重要的一个问题,我们后期再谈。

相关推荐
2501_92495269几秒前
Python深度学习入门:TensorFlow 2.0/Keras实战
jvm·数据库·python
2401_891482173 分钟前
Python多线程与多进程:如何选择?(GIL全局解释器锁详解)
jvm·数据库·python
Predestination王瀞潞3 分钟前
6.3.1 软件->W3C XPath 1.0 标准(W3C Recommendation):XPath(XML Path Language)查询语言
xml·数据库·oracle
2401_851272993 分钟前
用Python实现自动化的Web测试(Selenium)
jvm·数据库·python
快乐柠檬不快乐10 分钟前
Java连接电科金仓数据库(KingbaseES)实战指南
java·开发语言·数据库
AllData公司负责人20 分钟前
AllData数据中台通过集成DolphinScheduler+Seatunnel实现SAP HANA数据库同步到Doris数据仓库
数据库·数据仓库·sap hana
2401_8463416520 分钟前
使用Python进行网络设备自动配置
jvm·数据库·python
深蓝轨迹25 分钟前
黑马点评-day02-缓存笔记
redis·笔记·缓存·mybatis
执笔画情ora34 分钟前
Postgresql管理-杀会话还是取消会话?
数据库·oracle
清风徐来QCQ41 分钟前
redis 面试可能会问的问题
数据库·redis·面试