redis数据类型(一)

 博主主页: 码农派大星.

    数据结构专栏:Java数据结构

 数据库专栏:数据库

JavaEE专栏:JavaEE

软件测试专栏:软件测试

关注博主带你了解更多知识

目录

1. String 字符串类型

常见命令:

1. set

2. get

3. MGET和MSET

4.SETNX

5. setex和psetex

计数命令:

1. INCR

2. INCRBY

3. DECR

4. DECYBY

5. INCRBYFLOAT

其他命令:

1. APPEND

2. GETRANGE

3. SETRANGE

4. STRLEN

2.String内部编码

3. 典型使⽤场景

缓存功能

计数功能 

共享会话

Session分散存储

Redis集中管理Session 

⼿机验证码

 4. hash类型

命令:

1. HSET

2. HGET

3. HEXISTS

4. HDEL

5. HKEYS

6. HVALS

7. HGETALL

8. HMGET

9. HLEN 

10. HSETNX

11. HINCRBY

12. HINCRBYFLOAT

5. hash内部编码

6. 使⽤场景


1. String 字符串类型

字符串类型是Redis最基础的数据类型,redis中的字符串,直接就是按照二进制的方式存储的(不会做任何的编码转换,存的是什么,取出来的就是什么),字符串类型的值实际可以是字符串,包含⼀般格式的字符串或者类似JSON、XML格式的字符串;数字,可以是整型或者浮点型;甚⾄是⼆进制流数据,例如图⽚,⾳频,视频等但是⼀个字符串的最⼤值不能超过512MB。

常见命令:

1. set

将string 类型的value设置到key中(如果key之前存在,则覆盖,⽆论原来的数据类型是什么。之前关于此key的TTL也全部失效)

SET key value [expiration EX seconds|PX milliseconds] [NX|XX]

SET命令⽀持多种选项:

EX seconds⸺使⽤秒作为单位设置key的过期时间。

PX milliseconds⸺使⽤毫秒作为单位设置key的过期时间。

NX ⸺只在key不存在时才进⾏设置,即如果key之前已经存在,设置不执⾏。

XX ⸺只在key存在时才进⾏设置,即如果key之前不存在,设置不执⾏。

返回值:

如果设置成功,返回OK

如果由于SET指定了NX或者XX但条件不满⾜,SET不会执⾏,并返回(nil)

2. get

获取key对应的value

如果key不存在,返回nil, value的数据类型必须为是string类型,不然会报错

3. MGET和MSET

MGET⼀次性获取多个key的值

MSET⼀次性设置多个key的值

如果对应的key不存在或者对应的数据类型不是string,返回nil

MGET key [key ...]

时间复杂度:O(N),N是key数量

4.SETNX

设置key-value但只允许在key之前不存在的情况下

5. setex和psetex

计数命令:

1. INCR

将key对应的string表⽰的数字加⼀,如果key不存在,则视为key对应的value是0

如果key对应的string不是⼀个整型或者范围超过了64位有符号整型,则报错。

2. INCRBY

将key对应的string表⽰的数字加上对应值,如果key不存在,则视为key对应的value是0

如果key对应的string不是⼀个整型或者范围超过了64位有符号整型,则报错。

INCRBY key decrement

时间复杂度:O(1)

返回值:integer类型的加完后的数值

3. DECR

将key对应的string表⽰的数字⼀,如果key不存在,则视为key对应的value是0

如果key对应的string不是⼀个整型或者范围超过了64位有符号整型,则报错。

4. DECYBY

将key对应的string表⽰的数字去对应值,如果key不存在,则视为key对应的value是0

如果key对应的string不是⼀个整型或者范围超过了64位有符号整型,则报错。


 DECRBY key decrement

5. INCRBYFLOAT

将key对应的string表⽰的浮点数加上对应的值。如果对应的值是负数,则视为减去对应的值。

如果key对应的不是string,或者不是⼀个浮点数,则报错

其他命令:

1. APPEND

如果key已经存在并且是⼀个string,命令会将value追加到原有string的后边。如果key不存在, 则效果等同于SET命令

2. GETRANGE

返回key对应的string的⼦串,由start和end确定(左闭右闭,可以使⽤负数表⽰倒数。-1代表 倒数第⼀个字符,-2代表倒数第⼆个,其他的与此类似。超过范围的偏移量会根据string的⻓度调整成正确的值

GETRANGE key start end

3. SETRANGE

覆盖字符串的⼀部分,从指定的偏移开始

SETRANGE key offset value

4. STRLEN

获取key对应的string的⻓度。当key存放的类似不是string时,报错


 STRLEN key

2.String内部编码

字符串类型的内部编码有3种:

int:8个字节的⻓整型

embstr:⼩于等于39个字节的字符串

raw:⼤于39个字节的字符串

Redis 会根据当前值的类型和⻓度动态决定使⽤哪种内部编码实现

3. 典型使⽤场景

缓存功能

Redis作为缓冲层,MySQL作为存储层,绝⼤部分请求的热点数据都是从Redis中获取。由于Redis具有⽀撑⾼并发的特性,所以缓存通常能起到加速读写

整体的思路:

应用服务器访问数据时,先查询redis,如果redis上数据存在了,就直接交给应用服务器,不会再访问数据库了,如果redis上数据不存在,再读取MySQL,把读到的结果交给应用服务器,同时把这个数据也写入redis中

计数功能 

⽤Redis作为计数的基础⼯具,可以实现快速计数、查询缓存的功能,同时数据可以异步处理或者落地到其他数据源

例如视频⽹站的视频播放次数可以使⽤ Redis来完成:⽤⼾每播放⼀次视频,相应的视频播放数就会⾃增1

共享会话

⼀个分布式Web服务将⽤⼾的Session信息(例如⽤⼾登录信息)保存在各⾃ 的服务器中,但这样会造成⼀个问题:出于负载均衡的考虑,分布式服务会将⽤⼾的访问请求均衡到 不同的服务器上,并且通常⽆法保证⽤⼾每次请求都会被均衡到同⼀台服务器上,这样当⽤⼾刷新⼀ 次访问是可能会发现需要重新登录,这个问题是⽤⼾⽆法容忍的

为了解决这个问题,可以使⽤Redis将⽤⼾的Session信息进⾏集中管理,在这种模 式下,只要保证Redis是⾼可⽤和可扩展性的,⽆论⽤⼾被均衡到哪台Web服务器上,都集中从 Redis 中查询、更新Session信息

Session分散存储

Redis集中管理Session 

⼿机验证码

很多应⽤出于安全考虑,会在每次进⾏登录时,让⽤⼾输⼊⼿机号并且配合给⼿机发送验证码, 然后让⽤⼾再次输⼊收到的验证码并进⾏验证,从⽽确定是否是⽤⼾本⼈。为了短信接⼝不会频繁访 问,会限制⽤⼾每分钟获取验证码的频率

以上介绍了使⽤Redis的字符串数据类型可以使⽤的⼏个场景,但其适⽤场景远不⽌于此.

 4. hash类型

在Redis中,哈希类型是指值本⾝⼜是⼀个键值对结构,形如key="key",value={{ field1, value1 }, ..., {fieldN, valueN } }

哈希类型中的映射关系通常称为field-value,⽤于区分Redis整体的键值对(key-value), 注意这⾥的value是指field对应的值,不是键(key)对应的值.

命令:

1. HSET

设置hash中指定的字段(field)的值(value)

 HSET key field value [field value ...]

时间复杂度:插⼊⼀组field为O(1),插⼊N组field为O(N)

2. HGET

获取hash中指定字段的值

HGET key field

时间复杂度:O(1)

返回值:字段对应的值或者nil

3. HEXISTS

判断hash中是否有指定的字段

HEXISTS key field

时间复杂度:O(1)

4. HDEL


删除hash中指定的字段

 HDEL key field [field ...]

时间复杂度:删除⼀个元素为O(1).删除N个元素为O(N).

返回值:本次操作删除的字段个数

5. HKEYS

获取hash中的所有字段

HKEYS key

时间复杂度:O(N),N为field的个数

返回值:字段列表

6. HVALS

获取hash中的所有的值

HVALS key

时间复杂度:O(N),N为field的个数.

返回值:所有的值

7. HGETALL

获取hash中的所有字段以及对应的值

 HGETALL key

时间复杂度:O(N),N为field的个数 

HLEN key

8. HMGET

⼀次获取hash中多个字段的值

HMGET key field [field ...

时间复杂度:只查询⼀个元素为O(1),查询多个元素为O(N),N为查询元素个数

返回值:字段对应的值或者nil

9. HLEN 

获取hash中的所有字段的个数

HLEN key

10. HSETNX

在字段不存在的情况下,设置hash中的字段和值

HSETNX key field value

时间复杂度:O(1)

11. HINCRBY

将hash中字段对应的数值加减指定的值

 HINCRBY key field increment

时间复杂度:O(1) 

返回值:该字段变化之后的值 

12. HINCRBYFLOAT

HINCRBY的浮点数版本

 HINCRBYFLOAT key field increment

5. hash内部编码

哈希的内部编码有两种:

ziplist(压缩列表):当哈希类型元素个数⼩于hash-max-ziplist-entries配置(默认512个)、 同时所有值都⼩于hash-max-ziplist-value配置(默认64字节)时,Redis会使⽤ziplist作为哈希的内部实现,ziplist使⽤更加紧凑的结构实现多个元素的连续存储,所以在节省内存⽅⾯⽐ hashtable更加优秀

hashtable(哈希表):当哈希类型⽆法满⾜ziplist的条件时,Redis会使⽤hashtable作为哈希 的内部实现,因为此时ziplist的读写效率会下降,⽽hashtable的读写时间复杂度为O(1)

6. 使⽤场景

作为缓存

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/937104.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

在 macOS 下安装和使用 Clang Static Analyzer

在 macOS 下安装和使用 Clang Static Analyzer 相对简单,因为 macOS 自带 Clang 编译器,并且工具链已经包含了静态分析器的功能。以下是详细步骤: 1. 检查系统自带的 Clang macOS 自带 Clang 编译器,安装在 Xcode 或 Xcode Comm…

docker简单私有仓库的创建

1:下载Registry镜像 导入镜像到本地中 [rootlocalhost ~]# docker load -i registry.tag.gz 进行检查 2:开启Registry registry开启的端口号为5000 [rootlocalhost ~]# docker run -d -p 5000:5000 --restartalways registry [rootlocalhost ~]# dock…

搭建mqtt服务端并在Spring Boot项目中集成mqtt

文章目录 一、MQTT1.MQTT 的特点2.MQTT 的工作原理3.MQTT 的应用场景 二、EMQX(服务端)1.EMQX 的特点2.安装 三、客户端1.MQTTX2.EMQX后台建客户端3.H5页面客户端4.Spring Boot集成mqtt做客户端 一、MQTT MQTT(Message Queuing Telemetry Transport,消息…

Easysearch Java SDK 2.0.x 使用指南(一)

各位 Easysearch 的小伙伴们,我们前一阵刚把 easysearch-client 更新到了 2.0.2 版本!借此详细介绍下新版客户端的使用。 新版客户端和 1.0 版本相比,完全重构,抛弃了旧版客户端的一些历史包袱,从里到外都焕然一新&am…

《计算机视觉证书:开启职业发展新航道》

一、引言 在当今科技飞速发展的时代,计算机视觉技术正以惊人的速度改变着我们的生活和工作方式。从智能手机的人脸识别解锁到自动驾驶汽车的环境感知,计算机视觉技术的应用无处不在。而计算机视觉证书作为这一领域的专业认证,其作用愈发凸显…

ubuntu 用 ss-tproxy的最终网络结构

1、包含了AD广告域名筛选 2、Ss-tproxy 国内国外地址分类 3、chinadns-ng解析 4、透明网关 更多细节看之前博客 ubuntu 用ss-TPROXY实现透明代理,基于TPROXY的透明TCP/UDP代理,在 Linux 2.6.28 后进入官方内核。ubuntu 用 ss-tproxy的内置 DNS 前挂上 AdGuardHome…

OpenCV相关函数

一、二值化函数(threshold) 功能:将灰度图像转换为二值图像,通常用于图像分割。通过设置阈值,把图像中低于阈值的像素设为0,高于阈值的像素设为1。 参数: src:输入图像。 thresh&a…

前端html,vue使用第三方地图详细教程,以百度地图为例,实现地图标注,导航,定位,路线规划,坐标转换

目录 示例: 准备: ?编辑 开始: 1、新建页面,在script标签中引入百度地图的api数据,把自己在控制台创建的应用的ak替换上去 2、创建一个dom对象,设置宽高 3、在js中初始化地图 进阶: 1…

【经验分享】容器云搭建的知识点

最近忙于备考没关注,有次点进某小黄鱼发现首页出现了我的笔记还被人收费了 虽然我也卖了一些资源,但我以交流、交换为主,笔记都是免费给别人看的 由于当时刚刚接触写的并不成熟,为了避免更多人花没必要的钱,所以决定公…

【Liunx篇】基础开发工具 - vim

文章目录 一.vim的基本概念1.正常/命令模式2.插入模式3.底行模式/末行模式4.视图模式5.替换模式 二.vim的基本操作1.进入vim:2.退出vim: 三.vim正常模式命令集1.光标定位:2.复制/粘贴3.撤销4.剪切/删除5. 更改 四.vim底行模式命令集1.保存/退出2.调出行号…

数据结构---树(Tree)

1. 简介 在数据结构中,树是一种层次结构的数据结构,由节点(node)组成,其中每个节点通过边(edge)与其他节点连接。树是一种非线性的数据结构,广泛用于表示具有层级关系的数据。常见的…

【unity】从零开始制作平台跳跃游戏--界面的认识,添加第一个角色!

在上一篇文章中,我们已经完成了unity的环境配置与安装⬇️ 【Unity】环境配置与安装-CSDN博客 接下来,让我们开始新建一个项目吧! 新建项目 首先进入unityHub的项目页面,点击“新项目”: 我们这个系列将会以2D平台…

Ubuntu K8s

https://serious-lose.notion.site/Ubuntu-K8s-d8d6a978ad784c1baa2fc8c531fbce68?pvs74 2 核 2G Ubuntu 20.4 IP 172.24.53.10 kubeadmkubeletkubectl版本1.23.01.23.01.23.0 kubeadm、kubelet 和 kubectl 是 Kubernetes 生态系统中的三个重要组件 kubeadm: 主…

【ARM】ARM架构麒麟V10安装jdk1.8

ARM架构麒麟V10安装jdk1.8,就一句话安装 yum install java-1.8.0-openjdk java-1.8.0-openjdk-devel 关注我,继续【ARM】安装mysql 简单快捷。

Redis--高并发分布式结构

目录 一、引言 二、redis 1.什么是redis? 三、基础概念 1.什么是分布式? 2.应用服务和数据库服务分离 3.负载均衡 4.分库分表 5.微服务架构 四、总结 一、引言 本篇文章就简单介绍一下什么是redis,以及一些关于高并发和分布式结构的…

Repo管理

文章目录 前言Repo介绍清单仓库清单仓库的组成 初始化Repo同步远程仓库Repo实际应用 前言 我们知道,Git是用来管理某一个仓库,那当一个项目用到了多个仓库时,怎么来同步管理这些仓库呢?这个时候就可以引入Repo管理。 Repo介绍 …

python 数据分析之地图数据绘制

python 数据分析之地图数据绘制 1、根据历史的2023年GDP数据做地图分析 import numpy as np import matplotlib import matplotlib.pyplot as plt matplotlib.rcParams[font.family] SimHei import pandas as pd import folium from folium import Map import geopandas as…

分治算法(单选题)

2-1 分数 2 下列多少种排序算法用了分治法? 堆排序插入排序归并排序快速排序选择排序希尔排序 A.2 B.3 C.4 D.5 正确答案 A 2-2 分数 2 分治法的设计思想是将一个难以直接解决的大问题分割成规模较小的子问题,分别解决问题,最后将子…

探索 HTTP 请求头中的 “Host” 字段及其安全风险

探索 HTTP 请求头中的 “Host” 字段及其安全风险 大家好,今天我们来聊聊 HTTP 请求头中的“Host”字段,以及它的使用方法和安全风险。 什么是Host字段 在 HTTP 请求头中,“Host”字段是一个至关重要的部分。它告诉服务器,我们…

将 Ubuntu 22.04 LTS 升级到 24.04 LTS

Ubuntu 24.04 LTS 将支持 Ubuntu 桌面、Ubuntu 服务器和 Ubuntu Core 5 年,直到 2029 年 4 月。 本文将介绍如何将当前 Ubuntu 22.04 系统升级到最新 Ubuntu 24.04 LTS版本。 备份个人数据 以防万一,把系统中的重要数据自己备份一下~ 安装配置SSH访问…