redis入门学习

news2024/11/24 9:12:32

redis基本数据结构

redis的返回值

  • 在设置一个key-value对的时候通常会返回ok告诉我们操作成功了,1代表成功,0代表失败,通常会根据返回值的不同处理不同的业务逻辑
  • redis.cn来查看命令

全局操作

  • flushdb清空内存数据库
  • keys *展示所有存储结构名
  • del db删除某个内存结构

string

一个string键最大能存储512MB

> SET runoob "菜鸟教程"

> GET runoob

INCR key # 原子执行加一

incr key increment # 原子执行加increment

decr key

decrby key decrement

setnx key value  # 只有key不存在的时候

删除操作

DEL runoob

二进制操作

setbit key offset value  # 设置offset处值为value

getbit key offset

bitcount key [start end]
# 签到功能后台实现
setbit sign:10001:202106 1 1  # 某月某天签到情况
bitcount sign:1001:202106  	# 查看当月其签到次数
getbit sign:1001:202106 2 	# 查看当月第二天天签到次数

分布式锁

setnx lock 1  	# 获取锁
del lock 		# 释放锁

# 其他操作

Hash

每个hash可以存储 2 32 − 1 2^{32} - 1 2321个键值对

hmset

HMSET runoob field1 Hello field2 World

hget runoob field1

hmget runoob field1 field2

hgetall runoob

hincrby key field number

  • 只能对数值字段+

hdel key field

  • 删除某key上的键值对

List

简单的字符串列表,底层由循环双向链表实现

列表最多可存储 2 32 − 1 2^{32} - 1 2321 元素 (4294967295, 每个列表可存储40多亿)。

lpush runoob redis
rpush runoob mongodb
lpop runoob
rpop runoob

lrange runoob 0 1  # [0, 1] 左闭右闭

# 删除前i次出现的值为value的元素
lrem runoob count value
- lrem runoob 2 king # 删除前2次出现的king  如果有三个king则删除前2个

# 修剪功能 将list修剪为只有start,end中的元素
ltrim runoob 0 0 # 只保留第一个元素

设置阻塞超时队列

不存在list队列
brpop list 0永久阻塞等待回应
阻塞lpush list 1
解开阻塞得到数据1返回格式为
1) "list"
2) "mark"
(23.11s)阻塞23
不存在list因为被立即pop

Set

RedisSetstring 类型的无序集合。

集合是通过哈希表实现的,所以添加,删除,查找的复杂度都是 O(1)。

sadd runoob redis
smembers runoob

scard runoob  # 统计元素个数

sismember runoob vico  # 查看vico在不在runoob中

srandmember key [count]# 随机取出一个元素(或者多个)出来

spop members # 移除并返回一个随机元素

sdiff key [key...] # 返回指定所有集合的成员的差集

sinter key [key...] # 返回交集

sunion key [key...] # 返回并集

集合内元素的唯一性,第二次插入的元素将被忽略

zset

Redis zsetset一样也是string类型元素的集合,且不允许重复的成员。

不同的是每个元素都会关联一个double类型的分数。

redis正是通过分数来为集合中的成员进行从小到大的排序。

zset的成员是唯一的,但分数(score)却可以重复。

zadd key score member

添加元素到集合,元素在集合中存在则更新对应score

zadd runoob 0 redis
zadd runoob 0 mongodb
zadd runoob 0 rabbitmq

zrange runoob 0 -1 [withscores]

zcard runoob # 返回key的个数

zincrby runoob 11 member # 给member的分数加11 

zrangebyscore runoob 0 1000

根据score范围查找

redis的存储结构

string类型

动态字符串(sdssds.h

查看源码typedef char* sds;sds就是char*类型

针对不同的字符串长度用不同的数据结构(为了节约内存)

struct __attribute__ ((__packed__)) sdshdr8 {
    uint8_t len; /* used */
    uint8_t alloc; /* 分配的长度  为了进行惰性删除 */
    unsigned char flags; /* 标识字符串类型 */
    char buf[];
};
  • 上述是字符串长度小于 2 8 2^8 28时的存储结构,其他还有sdshdr16sdshdr32sdshdr64

  • 柔性数组:一次malloc,一次free就可以,内存连续

    分配时的代码

    s = malloc(sizeof(struct sdshdr8) + 64);
    return s + sizeof(struct sdshdr8);  // sds的起始地址
    

    释放

    free(sds - sizeof(struct sdshdr8));
    

存储结构

字符串长度小于等于 20能转成整数,则使用 int 存储;

字符串长度小于等于 44,则使用 embstr 存储;

字符串长度大于 44,则使用 raw 存储;

list类型

双向链表结构

查看源码:

一个quicklist,尾部链表的头节点和尾部节点
在这里插入图片描述

quicklistNode是一个双向链表

typedef struct quicklistNode {
    struct quicklistNode *prev;
    struct quicklistNode *next;
    unsigned char *entry;  // 存储的值
    size_t sz;             /* entry size in bytes */
    unsigned int count : 16;     /* count of items in listpack */
    unsigned int encoding : 2;   /* RAW==1 or LZF==2 */
    unsigned int container : 2;  /* PLAIN==1 or PACKED==2 */
    unsigned int recompress : 1; /* was this node previous compressed? */
    unsigned int attempted_compress : 1; /* node can't compress; too small */
    unsigned int extra : 10; /* more bits to steal for future usage */
} quicklistNode;

数据压缩

  • 元素长度小于48,不压缩
  • 元素压缩前后长度差不超过8,不压缩

Hash

第二层hashvalue值只能是string类型

查询插入删除都是O(1)

set

底层实现

  • 如果存储的是整数,则底层是整数数组(有序),便于交并差集
  • 如果存储的是字符串,则底层是hash

存储结构

  • 元素素都为整数且节点数量小于等于 512set-max-intset-entries),则使用整数数组存储;
  • 元素当中有一个不是整数或者节点数量大于 512,则使用字典 存储;

时间复杂度

如果存储的是数字则smembers的时间复杂度为O(nlogn)

如果存储的是字符串则时间复杂读为o(1)

zset

存储结构

  • 节点数量大于128或者有一个字符串长度大于64使用跳表(skiplist

  • 节点数量小于等于128且所有字符串长度小于等于64则使用ziplist存储

redis抽象层次

  • redis没有创建数据结构的命令

    • 设置的同时创建
    • 添加的同时创建
  • redis有删除kv的命令,但是v中没有元素时会自动删除kv

  • 阻塞连接概念

    brpop  # 队列没有数据pop的话就阻塞 或者设置超时时间
    
  • 通过命令的组合实现其他数据结构

    • lpush + lpop
      
      rpush + rpop
      
    • 队列

      lpush + pop
      
      rpush + lpop
      
    • 阻塞队列 多个队列则先来先服务

      lpush + brpop
      
      rpush + brpop
      
  • 通过组合数据结构实现功能

    hash + list  # list装购物车结构
    hash + set # set装在线玩家id
    hash + zset  # zset装排行榜
    

key的数量

  • 无线增长 并且性能不会随着数量增加而减少,因为是hash
    • 代价是扩容缩容渐进式hash

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

第十八章:MySQL8其他新特性

第十八章:MySQL8其他新特性 18.1:MySQL8新特性概述 ​ MySQL从5.7版本直接跳跃发布了8.0版本 ,可见这是一个令人兴奋的里程碑版本。MySQL 8版本在功能上做了显著的改进与增强,开发者对MySQL的源代码进行了重构,最突出…

2023-06-08 Unity AssetBundle1——AB包介绍与使用

文章目录 一、AB 包介绍二、AB 包资源打包(一)导入 AB 包(二)将资源关联 AB 包(三)打包参数选项(四)打包结果(五)AB 包信息 三、加载 AB 包资源(一…

如何让访问者能更快地加载出你的网站?

​  在当今互联网时代,网站已成为人们获取信息、交流互动、进行商业活动等的主要场所之一。然而,由于网络环境的复杂性和不确定性,用户在访问网站时常常会遇到访问缓慢、卡顿等问题,从而影响了用户的使用体验。为了让用户更快地…

【数据结构】常见排序算法——快速排序的三种实现、 hoare版本、挖坑法、前后指针版本

文章目录 1.常见排序2.快速排序2.1hoare版本2.2快速排序优化2.3挖坑法实现2.4前后指针实现 1.常见排序 2.快速排序 快速排序(Quick Sort) 是一种常见的排序算法,也是一种基于分治算法的排序。该算法的基本思想是将一个数据集分成两个子集&…

实验四、shell编程

一、实验目的 1.了解shell的特点和主要种类。 2.掌握 shel1 脚本的建立和执行方式。 3.掌握bash的基本语法。 4.学会编写shell 脚本。 二、实验内容 shell 脚本的建立和执行。历史命令和别名定义。shell变量和位置参数、环境变量。bash的特殊字符。一般控制结构。算术运算及…

Redis事务和管道

一、Redis事务 1、定义 可以一次执行多个命令,本质上是一组命令的集合。一个事务中的所有命令都会序列化,按顺序的串行化执行而不会被其他命令插入,不能加塞。 2、作用 一个队列中,一次性、顺序性、排他性的执行一系列命令。 …

第Y3周:yolov5s.yaml文件解读

🍨 本文为🔗365天深度学习训练营 中的学习记录博客🍖 原作者:K同学啊|接辅导、项目定制 ✅本周任务:将yolov5s网络模型中第4层的C3*2修改为C3*1,第6层的C3*3修改为C3*2。 简单介绍: YOLOv5配置了…

企业Wiki和知识库-SaaS产品运营指南

内部Wiki也叫做企业Wiki,是员工可以存储、共享和协作创作的地方,将企业内部员工知识共享集中到一个地方,并且相关内容与其他团队成员协作完成,它可以包含企业内部的各种知识,从操作指南到培训手册,再到客户…

RabbitMQ - 延迟队列

RabbitMQ - 延迟队列 延迟队列介绍RabbitMQ 中的 TTL整合 springboot队列 TTL延时队列TTL优化Rabbitmq 插件实现延迟队列总结 延迟队列介绍 延迟队列概念: 延时队列,队列内部是有序的,最重要的特性就体现在它的延时属性上,延时队列中的元素是…

《Lua程序设计》--学习3

输入输出 简单I/O模型 Lua 文件 I/O | 菜鸟教程 (runoob.com) 暂留 补充知识 局部变量和代码块 Lua语言中的变量在默认情况下是全局变量,所有的局部变量在使用前必须声明 在交互模式中,每一行代码就是一个代码段(除非不是一条完整的命…

spark的高阶用法

广播变量broadcast 使用场景:本地集合变量和分布式变量(rdd)进行关联的时候使用 优点:1.可以节省io操作.2.减少executor的内存占用 #定义 map_list {(1,dawang,22),(2,xiaogou,333).....} broadcast sc..broadcast(map_list) #使用 for i in broadcast.value:print(i)累加器a…

【TA100 】 LDR与HDR

一、LDR和HDR的基本概念 1.HDR 、LDR、动态范围 ● Dynamic Range(动态范围)最高亮度/最低亮度 ● HDR High Dynamic Range ● LDR Low Dynamic Range ● ToneMapping:将超高的动态范围(HDR)转换到我们日常显示的屏…

指定英国名校|社会科学老师喜赴曼彻斯特大学访学研究

社会科学较理工科专业申请访问学者的难度更大,何况M老师还有学校、专业、时间等要求。最终我们为其落实了世界50强名校—曼彻斯特大学全球发展研究所的职位,专业方向高度契合。在对方行政办理流程时遇到一些阻力,好在有惊无险地完成了全部流程…

Simulink尝试双脉冲实验验证MOSFET二极管反向恢复的特性(附仿真模型)

目录 前言 双脉冲实验 Simulink仿真对比 总结 前言 最近在做交错串联的图腾柱单相PFC的项目,基于模型的开发,想要在仿真上实现过零点尖峰电流产生并通过软启动进行抑制,把整个过程都通过仿真实现出来,在这个过程中尝试了Simul…

深入 Synchroized 原理,从入门到精通

目录 一、倔强青铜 1.1 多线程一定快吗? 1.2 上下文切换 1.3 测试上下文切换次数 1.4 Java内存模型 1.5 主内存与工作内存之间的数据交互过程 二、秩序白银 2.1 多线程带来的可见性问题 2.2 多线程带来的原子性问题 2.3 多线程带来的有序性问题 三、荣耀…

Yolov5涨点神器:RIFormerBlock助力检测|CVPR2023|RIFormer:无需TokenMixer也能达成SOTA性能的极简ViT架构

1.RIFormer介绍 论文:https://arxiv.org/pdf/2304.05659.pdf 本文基于重参数机制提出了RepIdentityFormer方案以研究无Token Mixer的架构体系。紧接着,作者改进了学习架构以打破无Token Mixer架构的局限性并总结了优化策略。搭配上所提优化策略后,本文构建了一种极致简单且…

目标检测算法:Faster-RCNN论文解读

目标检测算法:Faster-RCNN论文解读 前言 ​ 其实网上已经有很多很好的解读各种论文的文章了,但是我决定自己也写一写,当然,我的主要目的就是帮助自己梳理、深入理解论文,因为写文章,你必须把你所写的东西表…

Python爬虫——爬取阳光高考专业数据并对所有专业进行数据分析

前言 阳光高考是中国高考信息网,覆盖了中国所有院校以及所有专业信息。本文目的是爬取阳光高考的专业信息,包括专业名称,专业代码,专业简介,男女比例,在校生规模,就业方向,平均薪资…

LVS负载均衡 DR模式

目录 -----------------DR模式 LVS负载均衡群集部署----------------------------------- 1.配置负载调度器(192.168.110.100) 2.部署共享存储(NFS服务器:192.168.80.13) 3.配置节点服务器(192.168.80.…

H5吊起微信小程序(适用于从短信、邮件、微信外网页等场景打开小程序任意页面)

​1.实现功能 H5页面中实现打开微信小程序的功能用户在网页中一键唤起小程序 2.前提条件 必须是企业的小程序获取AppID,也就是小程序唯一凭证,可在微信公众平台 - 设置 - 开发设置」页中获得。(需要已经成为开发者,且帐号没有异…