2.Redis背景和使用场景

Redis:一个在内存中存储数据的中间件;

1.Redis一些特性(优点)

1)内存存储数据;key-value存储,非关系型数据库

2)可编程性,可以用脚本语言Lua操作;

3)可拓展性,Redis支持在原有的功能上在进行拓展,提供了一组API。

通过C,C++,Rust可编写Redis扩展(本质是动态库)。

4)持久性,Redis把内存放在内存上,内存是易失的;

内存为主,硬盘为辅;(硬盘备份内存数据,Redis重启了,可以加载硬盘数据到内存)

5)集群,Redis支持集群;

水平拓展,类似于"分库分表",引入多个集群,引入多个Redis缓存;

6)高可用性,重启可恢复数据(硬盘备份)

2.Redis为什么快?

1)内存存储,比硬盘存储的数据库,快很多

2)核心功能都是简单逻辑,简单地操作内存数据结构

3)网络角度,Redis采用了IO多路复用技术(epoll)

4)Redis采用单线程模型,避免线程竞争开销(新版本引入多线程,但针对网络)

多线程高效前提:CPU密集型任务,多线程重复利用CPU资源;

5)(争议)Redis使用C语言开发

3.使用场景

数据库、缓存、消息队列(服务器)

为什么消息队列不适用?

Redis的session storage理解:

HTTP协议是无状态、无连接的,为了保证用户的体验;引入了cookie,后为了安全性引入了session,session是保存在服务器内部的;因此可以用Redis作为缓存进行存储用户的session。

相关推荐
摇滚侠5 小时前
阿里云安装的 Redis 在什么位置,如何找到 Redis 的安装位置
redis·阿里云·云计算
啦啦啦_99995 小时前
Redis-2-queryFormat()方法
数据库·redis·缓存
forestsea7 小时前
深入理解Redisson RLocalCachedMap:本地缓存过期策略全解析
redis·缓存·redisson
佛祖让我来巡山8 小时前
Redis 为什么这么快?——「极速快递站」的故事
redis·redis为什么快?
啦啦啦_99999 小时前
Redis-0-业务逻辑
数据库·redis·缓存
自不量力的A同学10 小时前
Redisson 4.2.0 发布,官方推荐的 Redis 客户端
数据库·redis·缓存
fengxin_rou10 小时前
[Redis从零到精通|第四篇]:缓存穿透、雪崩、击穿
java·redis·缓存·mybatis·idea·多线程
是阿楷啊11 小时前
Java大厂面试场景:音视频场景中的Spring Boot与微服务实战
spring boot·redis·spring cloud·微服务·grafana·prometheus·java面试
笨蛋不要掉眼泪11 小时前
Redis哨兵机制全解析:原理、配置与实战故障转移演示
java·数据库·redis·缓存·bootstrap
ALex_zry1 天前
Redis Cluster 分布式缓存架构设计与实践
redis·分布式·缓存