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

相关推荐
码农小站1 小时前
ClickHouse 时间范围查询:精准筛选「本月数据」
数据库
paopaokaka_luck2 小时前
基于SpringBoot+Vue的非遗文化传承管理系统(websocket即时通讯、协同过滤算法、支付宝沙盒支付、可分享链接、功能量非常大)
java·数据库·vue.js·spring boot·后端·spring·小程序
小疯仔2 小时前
navicat导出数据库的表结构
数据库
TOSUN同星2 小时前
干货分享 | TSMaster DBC编辑器操作指南:功能详解+实战示例
数据库·oracle·编辑器·汽车·软件工程
huihui4503 小时前
一天一道Sql题(day01)
数据库
~尼卡~3 小时前
软考(软件设计师)数据库原理:事务管理,备份恢复,并发控制
数据库·软件设计师-软考
八九燕来3 小时前
Django双下划线查询
数据库·django·sqlite
眠りたいです4 小时前
Mysql常用内置函数,复合查询及内外连接
linux·数据库·c++·mysql
paopaokaka_luck4 小时前
智能推荐社交分享小程序(websocket即时通讯、协同过滤算法、时间衰减因子模型、热度得分算法)
数据库·vue.js·spring boot·后端·websocket·小程序
He.ZaoCha5 小时前
函数-1-字符串函数
数据库·sql·mysql