redis学习指南--概览篇

redis怎么学

官方学习网站:
redis.cn

1、整体了解redis

redis是一个内存数据库、kv数据库,数据结构数据库,redis中数据都是存储在redis中,可以通过key查找value,value可以有多种数据结构,有:string、list、hash、set、zset

2、redis怎么用,怎么操作redis数据结构

redis使用方式是一个请求响应交互模式,存储的是k-v对,value支持以下集中类型

  • string:支持二进制安全字符串,不会被特殊字符截断,支持\0
  • hash:唯一,无序
  • list:不唯一,插入有序
  • set:唯一,无序
  • zset:有序集合,唯一

使用命令进行交互:
set key value
setnx key value 设置不存在的key value对,不存在才会成功
del key

3、redis 中的value编码规则:

  • string类型:

有3种,在字符串长度小于等于20且为数字时为int,字符串长度大于44为raw,字符串长度小等于44时为embstr
raw类型是一种动态字符串,在字符串长度小于1M时,加倍扩容,大于1MB时,每次只扩1M,最多512M

  • list类型:

quicklist双向链表
ziplist压缩链表

  • hash:

字典dict:节点数量大于512或字符串长度大于64,
ziiplist:节点数量小于512且字符串长度小于64

  • set:

intset 元素都为整数且节点数量小于512
dict:节点数量小于512或有一个以上元素不为整数

  • zset:

skiplist – 数量大于68且有一个字符串长度大于64
ziplist – 节点数量小于68且字符串长度小于64

4、各种应用场景

  • 对象存储:

用json串组织对象属性作为value存储起来,一般对象不频繁变更时用来存储

  • 累加器:

对全局对象,用INCR key,一般用string类型
全局唯一值

  • 分布式锁:

确保只有一个进程或某个进程中的一个线程去操作一个全局唯一值
setnx加锁,因为锁存在时返回0,就可以用来定义为加锁失败,del解锁
setnx返回1,加锁成功

  • 位运算:

利用string是一个安全字符串,如应用在签到表,我们可以用位图来设置对应位的签到已否,对应位为1表示签到,为0表示未签到
如下:
setbit sign:10001:2002 1 1
表示设置用户10001在20年2月份第1天签到标识为1
sign:10001:2002为key,使用:是为了方便一些客户端工具使用,第一个1是位数,第二个1是值
获取对应第一天签到标识为:
getbit sign:10001:2002 1
获取总签到次数:
bitcount sign:10001:2002

不同编码的设计初衷是在数据量小的时候偏重于存储区效率高(占用内存少),数据量大时偏重运行速度快,避免阻塞其他业务应用请求

list:
list的关键特性是阻塞队列
消费方在请求某个key时如果不存在,则阻塞等待该key被生产方写入
在这里插入图片描述
利用该阻塞特性可以用来实现分布式公平锁
另外一个典型应用如**获取固定窗口数据,**像获取最近50条战绩
local record = KEYS[1]
redis.CALL(“LPUSH”, “says”, record)
redis.CALL(“LTRIM”, “says”, 0,4)

hash
对象存贮
通过field来确保唯一
可以用在对象属性经常修改场景的对象存储
同时操作多个hash字段:
hmset hash:10001 name lzs age 23 sex male
支持单独修改对象的某个属性,如
hset age 18
一次性获取所有字段值:
hgetall hash:10001
实际例子像购物车对象里面图片、名称、价格等都可作为属性

set一般用在共同交叉并集存在的场景,如共同关注
zset:
百度热榜 利用有序性
延时队列 – 将消息序列化成一个字符串作为zset的member,这个消息的到期处理时间作为score,定时查询到期的任务进行处理
分布式定时器
时间窗口限流

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

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

相关文章

Android修行手册 - POI操作Excel常用样式(字体,背景,颜色,Style)

点击跳转>Unity3D特效百例点击跳转>案例项目实战源码点击跳转>游戏脚本-辅助自动化点击跳转>Android控件全解手册点击跳转>Scratch编程案例点击跳转>软考全系列 👉关于作者 专注于Android/Unity和各种游戏开发技巧,以及各种资源分享&…

LeetCode算法题解(贪心)|LeetCode455. 分发饼干、LeetCode376. 摆动序列、LeetCode53. 最大子数组和

一、LeetCode455. 分发饼干 题目链接:455. 分发饼干 题目描述: 假设你是一位很棒的家长,想要给你的孩子们一些小饼干。但是,每个孩子最多只能给一块饼干。 对每个孩子 i,都有一个胃口值 g[i],这是能让孩…

一键批量转码:将MP4视频转为MP3音频的简单方法

随着数字媒体设备的普及,视频和音频格式转换的需求也越来越常见。其中,将MP4视频批量转换为MP3音频的需求尤为普遍。无论是为了提取视频中的背景音乐,还是为了在手机或电脑上方便地收听视频音频,这个过程都变得非常重要。接下来我…

Windows10+vs2015源码编译subversion

Windows源码安装subversion 一、运行环境 windows10 64位系统 VS2015完整安装 Subversion1.6.3 二、源码编译环境配置 1、python环境安装 python-2.4.msi2、perl环境安装 ActivePerl-5.8.8.822-MSWin32-x86-280952.msi3、openssl编译 C:>cd openssl-0.9.7f C:>p…

大数据毕业设计选题推荐-智慧消防大数据平台-Hadoop-Spark-Hive

✨作者主页:IT毕设梦工厂✨ 个人简介:曾从事计算机专业培训教学,擅长Java、Python、微信小程序、Golang、安卓Android等项目实战。接项目定制开发、代码讲解、答辩教学、文档编写、降重等。 ☑文末获取源码☑ 精彩专栏推荐⬇⬇⬇ Java项目 Py…

【CASS精品教程】cass3d基于DOM和DEM生成倾斜三维模型

和EPS一样,cass3d也可以生成三维模型。本文讲解 cass3d基于pix4d生成的正射影像DOM和DSM生成倾斜三维模型,并进行三维测图。 一、三维倾斜模型打开 打开cass11.0软件,打开三维窗口,点击打开模型,选择基于dom和dsm生成…

单位辨析 KB与K Mbit/s与kbit/s

在学习计算机相关专业课程的过程中,初学可能会搞混单位,其实我们只要注意带不带b即可, K103 KB210 带b就是以2为底 MB220 以此类推的单位 K bit/s1000 bit/s M bit/s1000 000 bit/s

Scala中的选项(Options )

Scala选项 选项 option 是一个包含一个值的容器,该值可以是两个不同值之一。 这两个值之一是“ none”,其他值可以是程序中有效的任何对象。 当接受从函数返回的值时可以使用Option,该函数可以在周期时间返回null,否则返回一些…

.NET快速对接极光消息推送

什么是消息推送? 很多手机APP会不定时的给用户推送消息,例如一些新闻APP会给用户推送用户可能感兴趣的新闻,或者APP有更新了,会给用户推送是否选择更新的消息等等,这就是所谓的“消息推送”。 常见的一些APP消息推送…

[LeetCode]-225. 用队列实现栈-232. 用栈实现队列

目录 225. 用队列实现栈 题目 思路 代码 232. 用栈实现队列 题目 思路 代码 225. 用队列实现栈 225. 用队列实现栈 - 力扣(LeetCode)https://leetcode.cn/problems/implement-stack-using-queues/description/ 题目 请你仅使用两个队列实现一个后…

【Python爬虫】网页抓取实例之淘宝商品信息抓取

之前我们已经说过网页抓取的相关内容 上次我们是以亚马逊某网页的产品为例 抓取价格、品牌、型号、样式等 该网页上价格、品牌、型号、样式等 都只有一个 如果网页上的目标内容 根据不同规格有多个 又该怎么提取呢? ▼如下图所示 当机身颜色、套餐、存储容量…

网页常用函数

1. 获取浏览器 Cookie 的值 使用 document.cookie 来获取 Cookie 的值。 const cookie name > ; ${document.cookie}.split(; ${name}).pop().split(;).shift();cookie(_ga); // Result: "GA1.2.1929736587.1601974046"2. 将 RGB 转换为十六进制 const rgbToHex…

python的输入input()和输出print(),及经验用法

python的输入和输出有什么用呢 各位,举个例子,在web应用当中,很多的用于与用户进行交互的输入输出大都是交给web前端的,尤其是交给javascript来完成,不仅简单、方便,而且能够减轻数据在服务器端与客户端之…

02-编码-YUV转H264

整体方案: 采集端:摄像头采集(YUV)->编码(YUV转H264)->RTMP推流 客户端:RTMP拉流->解码(H264转YUV)->YUV显示(SDL2) YUV转H264是一个视频编码的过程,具体的代码实现过程如下: #include <math.h> #include <stdlib.h> #ifdef __cplusplu…

另辟奚径-Android Studio调用Delphi窗体

大家都知道Delphi能调用安卓SDK&#xff0c;比如jar、aar等&#xff0c; 但是反过来&#xff0c;能在Android Studio中调用Delphi开发的窗体吗&#xff1f; 想想不太可能吧&#xff0c; Delphi用的是Pascal&#xff0c;Android Studio用的是Java&#xff0c;这两个怎么能混用…

layui table合计 totalRow 保留4位小数\ 异步请求数据的表格 新增行之后 如何更新数据

layui table合计 totalRow 保留4位小数: 例: totalRowMethod:(column: any, dataSource: any[]) > { let total 0; dataSource.forEach((item) > { total total Number(item[column.key]); …

Flutter——最详细(AppBar)使用教程

AppBar简介 Material Design 应用栏(标题栏) 使用场景&#xff1a; 顶部标题栏包括一些常用的菜单按钮 属性作用leading左边工具视图automaticallyImplyLeading左边图标的颜色title标题视图actions右边菜单按钮flexibleSpace其高度将与应用栏的整体高度相同bottom左侧底部文本内…

linux下IO模及其特点及select

ftp实现 模拟FTP核心原理&#xff1a;客户端连接服务器后&#xff0c;向服务器发送一个文件。文件名可以通过参数指定&#xff0c;服务器端接收客户端传来的文件&#xff08;文件名随意&#xff09;&#xff0c;如果文件不存在自动创建文件&#xff0c;如果文件存在&#xff0c…

阿里巴巴将开源720亿参数大模型;开源语言大模型演进史

&#x1f989; AI新闻 &#x1f680; 阿里巴巴将开源720亿参数大模型 摘要&#xff1a;在2023世界互联网大会乌镇峰会上&#xff0c;阿里巴巴集团CEO吴泳铭透露&#xff0c;阿里巴巴即将开源720亿参数大模型&#xff0c;这将是国内参数规模最大的开源大模型。目前&#xff0c…