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

相关推荐
市场部需要一个软件开发岗位3 小时前
JAVA开发常见安全问题:纵向越权
java·数据库·安全
海奥华23 小时前
mysql索引
数据库·mysql
2601_949593654 小时前
深入解析CANN-acl应用层接口:构建高效的AI应用开发框架
数据库·人工智能
javachen__4 小时前
mysql新老项目版本选择
数据库·mysql
Dxy12393102164 小时前
MySQL如何高效查询表数据量:从基础到进阶的优化指南
数据库·mysql
Dying.Light4 小时前
MySQL相关问题
数据库·mysql
蜡笔小炘4 小时前
LVS -- 利用防火墙标签(FireWall Mark)解决轮询错误
服务器·数据库·lvs
韩立学长4 小时前
基于Springboot泉州旅游攻略平台d5h5zz02(程序、源码、数据库、调试部署方案及开发环境)系统界面展示及获取方式置于文档末尾,可供参考。
数据库·spring boot·旅游
IT陈图图5 小时前
CANN生态数据引擎:minddata的缓存策略与性能调优
缓存·cann
Re.不晚5 小时前
MySQL进阶之战——索引、事务与锁、高可用架构的三重奏
数据库·mysql·架构