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进行排名

相关推荐
爱可生开源社区1 天前
2026 年,优秀的 DBA 需要具备哪些素质?
数据库·人工智能·dba
随逸1772 天前
《从零搭建NestJS项目》
数据库·typescript
加号32 天前
windows系统下mysql多源数据库同步部署
数据库·windows·mysql
シ風箏2 天前
MySQL【部署 04】Docker部署 MySQL8.0.32 版本(网盘镜像及启动命令分享)
数据库·mysql·docker
李慕婉学姐2 天前
Springboot智慧社区系统设计与开发6n99s526(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
数据库·spring boot·后端
百锦再2 天前
Django实现接口token检测的实现方案
数据库·python·django·sqlite·flask·fastapi·pip
tryCbest2 天前
数据库SQL学习
数据库·sql
jnrjian2 天前
ORA-01017 查找机器名 用户名 以及library cache lock 参数含义
数据库·oracle
十月南城2 天前
数据湖技术对比——Iceberg、Hudi、Delta的表格格式与维护策略
大数据·数据库·数据仓库·hive·hadoop·spark
Henry Zhu1232 天前
数据库:并发控制基本概念
服务器·数据库