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

相关推荐
cui_ruicheng19 分钟前
MySQL(四):数据类型与字段设计
数据库·mysql
皮皮学姐分享-ppx1 小时前
政府绿色采购数据库(2015-2024.3)
大数据·网络·数据库·人工智能·制造
闪电悠米3 小时前
黑马点评-Redis 消息队列-03_stream_consumer_group
开发语言·数据库·redis·分布式·缓存·junit·lua
DIY源码阁3 小时前
JavaSwing航班订票管理系统 - MySQL版
数据库·mysql
qqxhb3 小时前
47|成本与性能:缓存、批处理、模型路由与降级
缓存·批处理·智能模型路由·多级降级预案·成本预算
浪客灿心5 小时前
项目篇:模块设计与实现
数据库·c++
佛祖让我来巡山6 小时前
线上 Redis 突然“爆”了,怎么办?
redis·redis宕机·redis崩了·redis线上事故
流星白龙6 小时前
【MySQL高阶】26.事务(1)
数据库·mysql
三十..7 小时前
Redis 核心原理与高可用架构实践
运维·数据库·redis
这个DBA有点耶7 小时前
索引优化深潜(下):索引合并、ICP 与索引设计的实战法则
数据库·mysql·架构