Redis——常用数据类型string
目录
- 常用数据结构(类型)
- Redis单线程模型
- Reids为啥效率这么高?速度这么快?(参照于其他数据库)
- string
- set
- get
- MSET 和 MGET
- SETNX,SETEX,PSETEX
- incr,incrby,decr,decrby,incrbyfloat
- 其他命令
- 内部编码
- string类型的应用场景
- 计数功能
- 共享会话
- 手机验证码
常用数据结构(类型)
数据结构(类型) | 内部编码 | 描述 |
---|---|---|
string | raw | 最基本的字符串,类似于C++的char数组,或者java的byte数组 |
int | reds通常也可以用来实现一些“计数”这样的功能,当value就是一个整数的时候,此时可能redis会直接使用int来保存 | |
embstr | 针对短字符串进行的特殊的优化 | |
hash | hashtable | 最基本的哈希表 |
ziplist | 压缩列表,一般在哈希表元素比较少的时候可能就优化成ziplist 为啥要压缩?可能某些key的value是hash,此时,如果key特别多,对应的hash也特别多,但是每个hash又不大的情况下,就尽量去压缩,压缩之后就可以让整体占用的内存更小了 | |
list | linkedlist | 链表 |
ziplist | 压缩链表(从redis 3.2开始,引入了新的实现方式quicklist,同时兼顾了linkedlist和ziplist的优点 quicklist就是一个链表,每个元素又是一个ziplist把空间和效率都折中得兼顾到,比较类似于C++的deque(双端队列)) | |
set | hashtable | 哈希表 |
intset | 集合中存的都是整数 | |
zset | skiplist | 跳表,不同于普通的链表,每个节点都有多个指针域,从跳表上查询的元素的时间复杂度是O(logN) |
ziplist | 压缩链表 |
查看key对应的value的实际编码方式
object encoding key
Redis会根据当前的实际情况选择内部的编码方式
Redis单线程模型
- Redis只使用一个线程处理所有的命令请求,但不是说Redis服务器进程内部真的只有一个线程,其实也有多个线程,多个线程是在处理网络IO
假设现在有多个客户端,同时操作一个Redis服务器
当这两个客户端,同时并发的发起上述请求,是否会意味着服务器这边也会存在类似的线程安全问题呢?并不会,Redis服务器是一个单线程模型,保证了当前收到的这么多请求是串行执行的。 在多个请求同时到达Redis服务器,也是要先在队列中排队,再等待Redis服务器一个一个的去处里面的命令再执行,从另一方面看,Redis服务器是串行执行这么多个命令的
注意:Redis能够使用单线程模型很好的工作,原因主要在于redis的核心业务逻辑都是短平快的,消耗cpu资源也就不太吃多核。
Reids为啥效率这么高?速度这么快?(参照于其他数据库)
- Redis访问内存,数据库则是访问硬盘
- Redis核心功能,比数据库的核心功能更简单(数据库对于数据的增删查改这些功能,势必要花费更多的开销)
- 单线程模型,避免了一些不必要的线程竞争开销。
- 处理网络IO的时候,使用了epoll这样的IO多路复用机制
string
redis所有的key都是字符串,value的类型是存在差异的,redis中的字符串,直接就是按照二进制的方式存储的(二进制数据(图片,视频,文本,音频,…)),(不建议存储)音视频的体积可能会比较大,Redis对于string类型,限制了大小的最大是512M。
set
SET key value [expiration EX seconds|PX milliseconds] [NX|XX]
NX:如果key不存在,才设置 ,如果key存在,则不设置(返回nil)
XX:如果key存在,才设置(相当于更新key的value) ,如果key不存在,则不设置(返回nil)
//[]相当于一个独立的单元,表示可选项 可有可无//set key value ex 10
//相当于 set key value + expire key 10
- 如果key存在,创建新的键值对
- 如果key存在,则是让新的value覆盖旧的value,可能会改变原来的数据类型,原来的这个key的ttl也会失效
get
GET key//对于GET来说,只是支持字符串类型的value,如果value是其他类型,使用GET就会出错
//例
//127.0.0.1:6379> lpush key3 11 22 33
//127.0.0.1:6379>get key3
(error) WRONGTYPE Operation against akey holding the wrong kind of value
MSET 和 MGET
一次操作多次键值对
MGET key [key ...]
//一次获取对个key的值。如果对应的key不存在或者对应的数据类型不是string,返回nil、
//时间复杂度:O(n) n是key的数量
//返回值:对应value的列表MSET key value [key value ...]
//一次设置多个键值对
SETNX,SETEX,PSETEX
- setnx:不能存在才设置
- setex:[setex key seconds value] 设置value的同时设置过期时间(秒)
- psetex:[setex key millionseconds value] 设置value的同时设置过期时间(毫秒)
- 以上相当于针对set的一些常见写法,进行了缩写
incr,incrby,decr,decrby,incrbyfloat
- incr:针对value+1
INCR key
//此时的key对应的value必须是整数,如果不是整数会报错
//支持的整数返回为64位的整数,相当于C++中的long long
//返回值:value+1之后的值
//操作的key如果不存在,就会把这个key当做0来使用
- incrby:针对value+n
INCRBY key n //用法和incr一样,n可以是负数
- decr:针对value-1
DECR key // 用法和incr一样
- decrby:针对value-n
DECRBY key //用法和INCRBY一样
- incrbyfloat:针对value +/- 小数
INCRBYFLOAT key floatnum
//把key对应的value进行+-运算,运算的操作数可以是浮点数
上述操作的时间复杂度都是O(1) 由于redis处理命令的时候是单线程模型,多个客户端同时针对同一个key进行incr操作,不会近期“线程安全”问题
其他命令
- append
APPEND key value//如果key已经存在,并且是一个string,命令会将value追加到原有的string的后面。如果key不存在,则效果等同于set命令
//时间复杂度:O(1)
//返回值:追加完成之后的string的长度(单位是字节,不会对字符编码做处理,如果是中文字符,就按该终端的编码方式来计算,如utf8,一个汉字占3个字节)
//如果要在redis通过get获取中文字符串,需要在redis启动的时候加上一个 --raw这样的选项
//在linux操作的时候,不要乱按ctrl+s(xshell里是冻结当前画面的快捷键)--通过ctrl+q 解冻
- getrange
GETRANGE key start end
//返回值:string类型的字符串,时间复杂度O(n)//相当于获取字符串的子串 相当于C++中的substr
//在C++中和java中,大多数区间是左闭右开[),但是在redis中 是左闭右闭[start,end]
//正常下标是从0开始的整数,redis的下标是可以支持负数的(表示倒数第几个)
- setrange
SETRANGE key offset value//返回值:替换之后的新的字符串的长度
//offset为偏移量
//如果当前是中文字符串,进行setrange的时候可能会出现问题
//如果字符串不存在偏移量之前的内容会自动补上0x00 之后内容添加到最后一个0x00的后面
- strlen
STRLEN key//获取到的字符串的长度 单位是字节
内部编码
字符串类型的内部编码有三种:
- int:8个字节的长整形
- embstr:小于等于39个字节的字符串
- raw:大于39个字节的字符串
查看key对应的value的编码方式
OBJECT encoding key
Redis会根据当前值的类型和长度动态决定内部使用哪种编码方式实现
- 如果某个业务场景,有很多很多的key,类型都是string,但是每个value的string长度都是100左右,如果更关注与整体的内存空间,也可以考虑使用emstr,所以39这个数字只是对于通用的,对于不用的场景,可能会有不同的需求
string类型的应用场景
整体思路:
应用服务器访问数据的时候,先查询redis,如果redis上的数据已经存在了,就直接从redis取数据交给应用服务器,不继续访问数据库了
如果Redis上数据不存在,再读取Mysql,把读到的结果,返回给应用服务器同时,把这个数据也写入到Redis中
但是随着时间的推移,肯定会有越来越多的key在redis上访问不到,从而mysql读取并写入redis,此时数据就越来越多了
所以可与在把数据写给redis的同时,给这个key设置一个过期时间,当然Redis也在内存不足的时候,提供了淘汰策略
计数功能
许多应用都会使用Redis作为计数的基础工具,他可以实现快速计数,查询缓存的功能,同时数据可以异步处理或者落地到其他数据源。例如用户每播放一次视频,视频的播放次数就加一
共享会话
什么是会话,客户端和服务端在交互的过程中产生的一些专属于该客户端的中间状态的数据
如果每个应用服务器,维护自己的会话数据,此时彼此之间不共享,用户请求访问到不同的服务器上,就可能会出现一些不能正确处理的情况,这时候就可以用Redis将所有的管理起来
此时所有的会话数据,都被各个服务器共享了
手机验证码
- 生成验证码,用户输入手机号,获取验证码(限制1分钟内,最多获取5次验证码,或者每次获取验证码必须间隔30s)
- 检查验证码,把短信收到的验证码这一串数提交到系统中,系统进行验证验证码是否正确
相关文章:

Redis——常用数据类型string
目录 常用数据结构(类型)Redis单线程模型Reids为啥效率这么高?速度这么快?(参照于其他数据库) stringsetgetMSET 和 MGETSETNX,SETEX,PSETEXincr,incrby,decr…...
架构设计:负责网络、定时、坐下、站起、重连等,支持多类游戏的无锁房间
本文首发在这里 重中之重就是想实现无锁!无锁!无锁! 源码 servergolang 预计还会实现gate_server,接受并保持websocket长连接,按需双向流到game_server进行消息转发 未来上述服务均会以容器的形式由k8s自动化部署、…...

个人随想-gpt-o1大模型中推理链的一个落地实现
首先祝大家中秋节快乐。 最近openai又推出了新的模型openai o1还有它的mini版。官网的介绍,就是它的推理能力很强,比gpt-4o有很大的提升。 最近也跟同行在聊这个o1,看看落地方面有哪些可行性。在我们自己的实验上,把o1用…...
python解析ip范围,判断ip是否在ip范围内
目录 1. 背景 2. 代码使用示例 2.1 分割ip,横杠 (-) 的ip范围 2.2 判断ip在掩码(/)的范围内 2.3 判断ip在横杠(-)的范围内 2.3.1 格式:192.168.1.1-192.168.1.10 2.3.2 格式&…...
Springboot错误日志切面,找到post请求体被消费后的数据
问题记录:测试环境接口报错,日志里没有请求参数等信息,于是写了一个切面,但切面中获取不到 request的请求体,因为 post 请求体只能被消费一次,于是找解决办法 解决方法 既然 request 被消费了导致对应的请…...

【二十】【QT开发应用】listwidget右键菜单和删除item
创建项目,添加资源文件 在项目文件夹中创建resources资源文件夹。 在vs中打开qrc文件,选择添加资源文件。 选择我们resources资源文件中的所有文件作为资源文件。 最后不要忘记点击保存。 向ListWidget控件添加item 右键菜单 在.h文件中添加QMenu头…...

LabVIEW机动车动态制动性能校准系统
机动车动态制动性能测试系统通过高精度的硬件设备与LabVIEW软件的紧密配合,实现了对机动车制动性能的精确校准与评估。系统不仅提高了测试的精确性和效率,而且具备良好的用户交互界面,使得操作更加简便、直观。 项目背景 随着机动车辆数量的…...

Linux(CentOS8)服务器安装RabbitMQ
我安装了很久都没有成功, 各种问题, 每次的异常都不一样, 现将成功安装过程做个总结 安装前工作 确保已经安装了一些基础工具和组件库 下载安装包 https://www.erlang.org/patches/otp-24.3.4.5 https://github.com/rabbitmq/rabbitmq-server/releases/download/v3.9.15/ra…...

R语言进行无序多分类Logistic回归
在临床研究中,接触最多的是二分类数据,如淋巴癌是否转移,是否死亡,这些因变量最后都可以转换成二分类0与1的问题。然后建立二元logistic回归方程,可以得到影响因素的OR值。但有时我们也会接触到多分类结局数据…...

Maven从入门到精通(三)
一、Settings 配置 settings.xml 用来配置 maven 项目中的各种参数文件,包括本地仓库、远程仓库、私服、认证等信息。 全局 settings、用户 setting、pom 的区别: 全局 settings.xml 是 maven 的全局配置文件,一般位于 ${maven.home}/conf…...

Red Hat 和 Debian Linux 对比
原图的作者(https://bbs.deepin.org/post/209759) Red Hat Enterprise Linux https://www.redhat.com/ CentOS Linux https://www.centos.org/ Fedora Linux https://fedoraproject.org/ Debian https://www.debian.org/ Ubuntu https://cn.ubuntu.com/ https://ubuntu.c…...

Axure设计之全屏与退出全屏交互实现
在Axure RP中,设计全屏与退出全屏的交互功能可以极大地提升用户体验,尤其是在展示产品原型或进行演示时。本文将详细介绍如何在Axure RP中通过结合JavaScript代码实现全屏与退出全屏的交互效果。 Axure原型设计web端交互元件库:https://…...

如何测试出自己电脑的网络速度(网速)?
首先电脑上要下载一个这样的一个电脑软件:360安全卫士 1、打开软件之后,选择【网络安全】 2、选择【宽带测速器】 3、点击之后,即可开始检测当前网络速度,等待大概十几秒后会出现结果,如下: 位置①:显示…...

如何利用AI进行有效的科技产品发布
如果你们公司即将推出一款具有颠覆性的软件,你大概已经了解了科技在现代市场中的价值。 但像AI这样的技术不仅仅是有效的产品组成部分,它们还可以帮助将这些产品推向客户(或安装到他们的电脑上)。 Kuno Creative明白AI在科技营销…...
二层、三层网络基本原理
文章目录 二层网络整体拓扑相关配置配置namespace创建switch创建veth设备配置veth的IP启动veth 测试 三层网络配置vm1配置vm2配置 测试 二层网络 我们用Linux bridge模拟现实中的switch,用namespace模拟连接在交换机上的pc 整体拓扑 ------------------ ----…...

全面掌握 Jest:从零开始的测试指南(上篇)
随着JavaScript在前后端开发中的广泛应用,测试已成为保证代码质量的关键环节。 为什么需要单元测试 在我们的开发过程中,经常需要定义一些算法函数,例如将接口返回的数据转换成UI组件所需的格式。为了校验这些算法函数的健壮性,部…...
Go 交叉编译
Mac 下编译 Linux 和 Windows 64位可执行程序 Linux: CGO_ENABLED0 GOOSlinux GOARCHamd64 go build main.go Windows: CGO_ENABLED0 GOOSwindows GOARCHamd64 go build main.go Linux 下编译 Mac 和 Windows 64位可执行程序 Mac: CGO_ENABLED0 G…...
goctl安装失败
今天遇到一个很奇怪的问题 在阿里云的ubuntu服务器上远程安装goctl:go install github.com/zeromicro/go-zero/tools/goctllatest,后面会断开ssh连接,就再也连不上了,connecting with ssh timed out。在阿里云的workbench上连接显…...

DebateGPT:通过多智能体辩论监督微调大模型
人工智能咨询培训老师叶梓 转载标明出处 这些模型的训练通常依赖于资源密集型的人工反馈,这不仅成本高昂,而且耗时。为了解决这一问题,一篇名为《FINE-TUNING LARGE LANGUAGE MODELS WITH MULTI-AGENT DEBATE SUPERVISION》的论文提出了一种…...

【最新综述】基于深度学习的超声自动无损检测(下)
4.Levels of automation 5.Basic axioms for DL-based ultrasonic NDE 在回顾了最新技术和每个自动化级别的贡献之后,我们不难发现,目前的数字语言方法论在不同论文之间存在着很大的差异。例如,有些作者提出了同时处理不同步骤的模型[121]&…...
【Linux】shell脚本忽略错误继续执行
在 shell 脚本中,可以使用 set -e 命令来设置脚本在遇到错误时退出执行。如果你希望脚本忽略错误并继续执行,可以在脚本开头添加 set e 命令来取消该设置。 举例1 #!/bin/bash# 取消 set -e 的设置 set e# 执行命令,并忽略错误 rm somefile…...

CTF show Web 红包题第六弹
提示 1.不是SQL注入 2.需要找关键源码 思路 进入页面发现是一个登录框,很难让人不联想到SQL注入,但提示都说了不是SQL注入,所以就不往这方面想了 先查看一下网页源码,发现一段JavaScript代码,有一个关键类ctfs…...
golang循环变量捕获问题
在 Go 语言中,当在循环中启动协程(goroutine)时,如果在协程闭包中直接引用循环变量,可能会遇到一个常见的陷阱 - 循环变量捕获问题。让我详细解释一下: 问题背景 看这个代码片段: fo…...

Qt/C++开发监控GB28181系统/取流协议/同时支持udp/tcp被动/tcp主动
一、前言说明 在2011版本的gb28181协议中,拉取视频流只要求udp方式,从2016开始要求新增支持tcp被动和tcp主动两种方式,udp理论上会丢包的,所以实际使用过程可能会出现画面花屏的情况,而tcp肯定不丢包,起码…...

大型活动交通拥堵治理的视觉算法应用
大型活动下智慧交通的视觉分析应用 一、背景与挑战 大型活动(如演唱会、马拉松赛事、高考中考等)期间,城市交通面临瞬时人流车流激增、传统摄像头模糊、交通拥堵识别滞后等问题。以演唱会为例,暖城商圈曾因观众集中离场导致周边…...

2025盘古石杯决赛【手机取证】
前言 第三届盘古石杯国际电子数据取证大赛决赛 最后一题没有解出来,实在找不到,希望有大佬教一下我。 还有就会议时间,我感觉不是图片时间,因为在电脑看到是其他时间用老会议系统开的会。 手机取证 1、分析鸿蒙手机检材&#x…...

IoT/HCIP实验-3/LiteOS操作系统内核实验(任务、内存、信号量、CMSIS..)
文章目录 概述HelloWorld 工程C/C配置编译器主配置Makefile脚本烧录器主配置运行结果程序调用栈 任务管理实验实验结果osal 系统适配层osal_task_create 其他实验实验源码内存管理实验互斥锁实验信号量实验 CMISIS接口实验还是得JlINKCMSIS 简介LiteOS->CMSIS任务间消息交互…...

项目部署到Linux上时遇到的错误(Redis,MySQL,无法正确连接,地址占用问题)
Redis无法正确连接 在运行jar包时出现了这样的错误 查询得知问题核心在于Redis连接失败,具体原因是客户端发送了密码认证请求,但Redis服务器未设置密码 1.为Redis设置密码(匹配客户端配置) 步骤: 1).修…...
在树莓派上添加音频输入设备的几种方法
在树莓派上添加音频输入设备可以通过以下步骤完成,具体方法取决于设备类型(如USB麦克风、3.5mm接口麦克风或HDMI音频输入)。以下是详细指南: 1. 连接音频输入设备 USB麦克风/声卡:直接插入树莓派的USB接口。3.5mm麦克…...

Ubuntu系统复制(U盘-电脑硬盘)
所需环境 电脑自带硬盘:1块 (1T) U盘1:Ubuntu系统引导盘(用于“U盘2”复制到“电脑自带硬盘”) U盘2:Ubuntu系统盘(1T,用于被复制) !!!建议“电脑…...