Redis的VALUE类型

Redis自我学习


Redis简介

继续往后推进,最近在学习redis的基本数据结构,首先在磁盘中的寻址空间为ms级别,而在内存中为ns级别,所以磁盘比内存在寻址上满了10W倍,也就是为什么mysql关系型数据库比NOSQL查询数据慢的原因之一。在MYSQL中,数据和索引都存储在硬盘中,真正查的时候要在内存中准备一个B+树(树干),把磁盘中的数据读到内存,再根据需要查找的数据索引再返回磁盘中寻找,找到之后再一次读进内存,依次循环,最终找到该记录。最终目的减少IO。
但是随着数据量大,mysql的性能会变低吗?不一定,如果表有索引,增删改会变慢,但查询速度需要区分,如果1个或少量查询,依然很快。但是并发量大的时候,会受硬盘带宽影响速度。(需要挨个从内存走,需要等待前面查询完再走)。在redis诞生之前,也有一款内存数据库,memcache,但是这款数据库淘汰的原因是value并没有设定它的类型,而像JSON一样表示复杂的数据结构,这种结构限制了对数据的操控,所以诞生了redis。
redis的value可以有5种类型,这不仅仅是有类型那么简单,也是因为redis对每种类型定义了众多操作。
redis是单进程、单线程、单实例的,可以并发很多请求,可是为什么单进程单线程却能速度变得很快呢?我们知道在Linux下真正实现AIO是很困难的,即便现在真正有了AIO的产品,也不是很理想,所以redis采用了kernel的epoll同步非阻塞的多路复用NIO技术(这一块可以看下netty与socket编程)。
在这里插入图片描述
Redis的默认端口号为6379,默认建立了16个库,库和库是分离的,相当于Mysql的表。

redis安装步骤

在centos上安装。
在这里插入图片描述

value类型

总结一下redis的常用5种类型。redis的key只能是字符串类型,而value却可以有很多种类型。value类型可以为string、set、sortset、list、hash。

redis的string类型

概念

string类型有字符串操作、数值操作以及位图操作。
在这里插入图片描述
对于各个操作,可以用help @string命令查看
在这里插入图片描述
在redis中有个很重要的概念,二进制安全。
在这里插入图片描述
Redis拿的是字节流,不会破坏编码,防止多语言开发的时候,需要转换类型。在数值中,99999长度为5,就是一个字节取。若计算
则拿出来转换为数值,会更新key的encoding的int,encoding存在的意义在于(对key做了优化)不需要再进行判断是否可以转为int类型,不需要排测过程,是一个加速过程(忽略)直接累加。而中文需要根据xshell的编码格式。Redis一定是要在用户端沟通编码与解码,redis内部是没有数据类型的,都是字节流存储。方便各种语言对redis进行操作。
在这里插入图片描述
对于中文的获取,必须加 --raw才能根据xshell的格式取获取不同编码的中文。
1.对于字符串操作,主要的操作是set,get。
2.对于数值操作,主要是加一个数字或者减一个数字
3.对于位图操作,setbit k1 5 1意思是在第5个二进制位上把0置为1
bitpos k1 1 1 1意思是第一个1为查找二进制位为1的位置,后两位是第几个字节。这里是从第一个字节到第一个字节。
bittop and endkey k1 k2 将k1与k2按位与操作,并返回至endkey键中。

setnx是一个很重要的概念,此方法与缓存击穿问题有关,能让单个线程通过setnx再加上过期时间解决缓存击穿问题。

在setbit的offset是下面的offset。
Setbit k1 5 1 <=====> 0000 1000
Bitpos是bitpos k1 1 1 1 意思是从第一个字节到第一个字节中寻找第一个出现二进制位为1的偏移量,需要再加上前面8位。
在这里插入图片描述
在这里插入图片描述

应用场景

位图的应用场景1:统计用户登录天数,且窗口随机。也就是假设需要在一年的最后2周之内计算用户的登录天数。用位图。
ket存的是用户名,分为365个bit位,某一天出现了登录状态,则某一位置为1.下列的-2 -1是redis支持反向索引,-2 -1也就是最后16天的统计。
一个用户一年只需要46字节存储
在这里插入图片描述
位图的应用场景2:618送礼物,需要准备多少礼物?
首先要确定活跃用户的统计,key把年份记录下来,而value的二进制位则代表用户。通过bitop or统计去年618前后3天的活跃人员数,再用bitcount统计。
在这里插入图片描述
数值的应用场景:抢购,秒杀,点赞,规避并发下对数据库的事务的操作,完全由redis内存操作代替。

Redis的List类型

在这里插入图片描述
在这里插入图片描述
list可以模拟不同的数据结构,栈、队列、数组和阻塞队列。
模拟栈,需要同向命令。比如:
在这里插入图片描述
在这里插入图片描述
模拟队列需要反向命令
在这里插入图片描述
在这里插入图片描述
模拟数组的下标获取值
在这里插入图片描述
在这里插入图片描述
模拟阻塞单播队列

在这里插入图片描述
等待获取k3的第一个值
在这里插入图片描述

在这里插入图片描述

此时输入队列一个元素,那么就不阻塞了。

Redis的Hash类型

redis本身就是Key-value,这里hash也是key-value结构。
在这里插入图片描述
应用场景:比如:再购物车上一个用户对应不同商品与数量。也可以有详情页。
Redis是内存的数据库,对值的操作非常快,当有了详情页,有很多很多字段的信息,给出名字拿出所有的values就出来了。点赞次数,浏览的次数,被收藏的次数,纪要被查询又要被计算,hash支持数值的计算。

Redis的Set类型

set是一种无重复的集合,不维护排序。
在这里插入图片描述
可以取两个key的交集
在这里插入图片描述
还可以用Sinterstore dest k1 k2

Sinterstore dest k1 k2 放到store中,为什么要有这个命令呢?但如果有这样需要,既要k2 k3数据也要k2 k3的交集,这个时候把k2 k3 的交集放到redis,有一次IO的时间。
在这里插入图片描述
并集SUNION
在这里插入图片描述
差集SDIFF,但是有方向性
在这里插入图片描述
在这里插入图片描述
set可以用来抽奖,抽奖方式有两种,一种是人多奖品少,还有一种是人少奖品多
在这里插入图片描述
spop是随机取出一个value。

Redis的Sorted_Set类型

类型(有序集) sorted set首先是set,需要有个维度,分值维度,按照分值进行排序。
如果以分值为1,按照字典序排序。
在这里插入图片描述
zrange与zrangebyscore
在这里插入图片描述

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

这里的zrevrange怎么取的呢?因为有双向链表,取的话是从小到大。

对相同的值做并集,这里可以用weights1 0.5赋值权重。
在这里插入图片描述
sorted_set内部数据结构用的是跳表
在这里插入图片描述
这里是随机造层。

假设需要找x23,那么在第一层中找到11,11还是比23小,那么往下去第二层,第二层中比x22大,但是比x45小,这时在下去,去找到x23。

牺牲了空间,成全了速度。越往上点越少。

  • 4
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
### 回答1: Fastjson是一个用于Java的高性能JSON处理库,可以方便地进行JSON的序列化和反序列化。反序列化是将JSON格式的数据转换为Java对象的过程。在Redis中存储的value可以是任意类型的数据,包括字符串、数字、列表、哈希等。当我们从Redis中获取到value时,需要将其反序列化为对应的Java对象才能进行进一步的操作。 使用Fastjson进行反序列化Redis value的步骤如下: 1. 导入Fastjson库:首先需要将Fastjson的库添加到项目的依赖中,可以通过Maven或手动下载并导入相应的jar包。 2. 获取Redis value:从Redis中获取到的value可以通过Redis客户端的API来获取,一般是以字符串的形式返回。 3. 使用Fastjson进行反序列化:将获取到的Redis value以字符串的形式传递给Fastjson的反序列化方法,然后指定要转换的Java对象的类型。Fastjson会自动将JSON字符串转换为对应类型的Java对象,可以直接进行操作。 示例代码如下: ```java import com.alibaba.fastjson.JSON; ... // 假设从Redis中获取到的value是一个包含学生信息的JSON字符串 String redisValue = redisClient.get("studentInfo"); // 使用Fastjson将JSON字符串反序列化为Student对象 Student student = JSON.parseObject(redisValue, Student.class); // 可以直接对student对象进行操作 System.out.println(student.getName()); System.out.println(student.getAge()); ... ``` 通过上述步骤,我们可以使用Fastjson方便地将Redis中的value反序列化为Java对象,从而可以在应用程序中对其进行进一步的操作。需要注意的是,Fastjson在进行反序列化时,需要确保JSON字符串的格式与目标Java对象类型的属性一一对应,否则可能会出现异常。 ### 回答2: Fastjson是一款Java语言中的快速JSON解析库,能够高效地将JSON字符串转换为Java对象。对于Redis而言,它可以将Redis存储的JSON格式的value值反序列化为Java对象。 在实际应用中,我们通常会使用Fastjson提供的`parseObject()`方法进行反序列化操作。首先,我们需要将Redis中获取到的JSON字符串作为参数传递给该方法,Fastjson会根据JSON的结构和定义的目标对象类型将其转换成对应的Java对象。 具体的使用步骤如下: 1. 首先,我们需要从Redis中获取到存储的JSON字符串。 2. 使用Fastjson的`parseObject()`方法将JSON字符串转换为Java对象。例如,如果我们希望将JSON字符串转换成User对象,可以使用如下代码: `User user = JSON.parseObject(jsonString, User.class);` 这里的`jsonString`是从Redis中获取到的JSON字符串,`User.class`表示目标对象的类型。 3. 对于嵌套的JSON结构,Fastjson也能够很好地支持反序列化操作。例如,假设User对象中包含了Address对象作为属性,我们同样可以使用`parseObject()`方法将其转换成对应的Java对象。 总结而言,Fastjson是一款高效的JSON解析库,可以帮助我们将Redis中存储的JSON格式的value值反序列化为Java对象。通过使用`parseObject()`方法,我们可以方便地将JSON字符串转换为目标对象,并且对于嵌套的JSON结构同样能够很好地支持。 ### 回答3: Fastjson是一种Java的JSON处理库,它提供了封装简单、速度快的特点,常用于序列化和反序列化JSON数据。在使用Fastjson进行反序列化时,可以将Redis中存储的JSON数据进行解析,转换为Java对象。 通常情况下,我们在往Redis中存储数据时会将数据转换为JSON格式,Fastjson可以将这些JSON数据转换为Java对象,方便我们在程序中进行操作。Fastjson提供了灵活的反序列化功能,可以将JSON字符串映射到Java对象的属性上,同时也支持从JSON数组中解析多个对象。 在反序列化Redis中的value时,我们可以首先使用Redis客户端从Redis中获取到相应的value,接着使用Fastjson的`parseObject`方法将这个value转换为Java对象。例如: ``` String redisValue = jedis.get("key"); // 从Redis中获取到value MyClass myObject = JSON.parseObject(redisValue, MyClass.class); // 使用Fastjson反序列化为Java对象 ``` 在上述代码中,`MyClass`是自定义的Java类,表示了一个与Redisvalue对应的数据模型,`redisValue`则是获取到的Redis value对应的字符串。`JSON.parseObject`方法会根据字符串的内容将其转换为与`MyClass`结构相同的Java对象。 需要注意的是,在反序列化时,要确保将数据转换为正确的数据类型,否则可能会导致类型转换错误或其他异常。此外,Fastjson也提供了更多的反序列化选项和定制能力,可以根据具体需要进行配置。 总之,Fastjson可以作为一个强大的工具,用于反序列化Redis中的value数据,将之转换为Java对象,便于在程序中进行进一步的处理和操作。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值