Redis的简单介绍(1)

Redis的简单介绍

Redis是一种"非关系型数据库", 与之相对的是"关系型数据库"例如最具代表的Mysql数据库,

Redis是一款高性能的内存数据库,数据的访问速度很快.

Redis的应用非常广泛. 常见的有: 在分布式系统中作为分布式锁, 会话存储, 计数器, 实时数据分析

Redis的数据读取速度快的原因:

下面列举两个重要的原因

1.Redis将数据储存在内存中,这种方式较Mysql这种将数据储存在硬盘上的方式, 大幅提升了数据读取的速度.

2.Redis在对数据进行操作时采用的是单线程模式, 但这并不是说Redis没有多线程. 单线程数据的操作模式不需要考虑多线程和锁冲突的问题使读取速度增快.

常见的基本数据类型

前言:

Redis的数据存储是按照键值对的形式进行存储(key-value).即一个键对应一个值.但需要注意的是

key的数据类型只能是string类型. 不一样的是value的类型有下列几种常见的类型.

String类型

虽然说是String类型,但能存储的不只是"字符串",包含: text(文本数据), serialized objects(序列化对象), binary arrays(二进制数组如:图片).

List类型

List类型是指数据以一个双向链表(记录了头尾位置)的形式进行储存且列表中存储的值是String类型,主要有以下几个特点

  • 插入数据的方式为头插法或者尾插法. 所以无论列表存储了多少元素. 插入数据的时间复杂度是一个常数.
  • 列表中的元素是有序(这里的有序并不是指升序,降序排列的. 指的是顺序一旦改变,这个列表就不是之前的列表了)的,这意味着可以通过索引下标获取某个元素或者某个范围的元素列表
  • 列表中的元素是允许重复的

Set类型

集合类型,一个Key中对应多个Value. 但一个Key中的Value是不能重复的 对多个Set之间可以进行交集,并集,差集运算. 运算方式与数学中的方式一致.

应用场景: 记录用户所浏览的记录的标签, 并按照所记录的标签推荐类似的内容.

Hash类型

数据的存储和redis的数据存储一样也是Key-Value结构, 为了避免混淆. 数据的存储的形式为

Field-Value形式. 同时一个key中可包含多个hash的键值对.

主要作用于:

  • 客户会话管理:将客户数据存储在哈希键中。为每个会话创建一个新的哈希键,并将会话字段添加到客户的哈希键中。当会话过期时,自动使会话键和客户哈希键中的会话字段过期。
  • 事件跟踪:使用哈希键存储过去一小时的事件。将每个事件的TTL(过期时间)设置为一小时。使用HLEN(可以计算键值对的数量)来统计过去一小时的事件。

Zset类型

在Set类型的基础上又为每一个value加上了一个分数(score). 并利用这个分数对Value进行排序

排序默认为升序排序.

需要注意的是: value不能重复,但score可以重复(不同的value可以包含相同的score), 而且Zset也可以进行交集,并集,差集运算.

最常见于排行榜, 为每个Key进行排名

相关推荐
栗子~~4 小时前
JAVA - 二层缓存设计(本地缓冲+redis缓冲+广播所有本地缓冲失效) demo
java·redis·缓存
隔窗听雨眠4 小时前
多活部署、CDN加速与边缘缓存全链路优化实战
缓存
星星也在雾里4 小时前
PgBouncer 解决 PostgreSQL 连接数超限 + 可视化监控
数据库·postgresql
未若君雅裁5 小时前
MyBatis 一级缓存、二级缓存与清理机制
java·缓存·mybatis
雨辰AI6 小时前
SpringBoot3 + 人大金仓读写分离 + 分库分表 + 集群高可用 全栈实战
java·数据库·mysql·政务
长城20246 小时前
关于MySql的ONLY_FULL_GROUP_BY问题
数据库·mysql·聚合列
常常有7 小时前
MySQL 底层执行原理:输入SQL语句到两阶段提交
数据库·sql·mysql
Mr. zhihao7 小时前
深入解析redis基本数据结构
数据结构·数据库·redis
m0_748839497 小时前
利用天正暖通CAD快速掌握风管数量统计的方法
数据库
随身数智备忘录7 小时前
什么是设备管理体系?设备管理体系包含哪些核心模块?
网络·数据库·人工智能