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和各种游戏开发技巧,以及各种资源分享&…

一键批量转码:将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生成…

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

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

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

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

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

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

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

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

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 应用栏(标题栏) 使用场景: 顶部标题栏包括一些常用的菜单按钮 属性作用leading左边工具视图automaticallyImplyLeading左边图标的颜色title标题视图actions右边菜单按钮flexibleSpace其高度将与应用栏的整体高度相同bottom左侧底部文本内…

linux下IO模及其特点及select

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

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

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

Linux的基本指令(1)

目录 快速认识的几个指令 pwd指令 mkdir指令 touch指令 cd指令 clear指令 whoami指令 ls指令 ls -l ls -la ls 目录名 ls -ld 目录名 文件 路径 路径是什么? 路径的形成 ​ 怎么保证路径必须有唯一性? ls -la隐藏文件 隐藏文件的是什…

Haproxy实现七层负载均衡

目录 Haproxy概述 haproxy算法: Haproxy实现七层负载 ①部署nginx-server测试页面 ②(主/备)部署负载均衡器 ③部署keepalived高可用 ④增加对haproxy健康检查 ⑤测试 Haproxy概述 haproxy---主要是做负载均衡的7层,也可以做4层负载均衡 apache也可…

在Spring Boot中使用JTA实现对多数据源的事务管理

了解事务的都知道,在我们日常开发中单单靠事务管理就可以解决绝大多数问题了,但是为啥还要提出JTA这个玩意呢,到底JTA是什么呢?他又是具体来解决啥问题的呢? JTA JTA(Java Transaction API)是…

Leetcode 剑指 Offer II 052. 递增顺序搜索树

题目难度: 简单 原题链接 今天继续更新 Leetcode 的剑指 Offer(专项突击版)系列, 大家在公众号 算法精选 里回复 剑指offer2 就能看到该系列当前连载的所有文章了, 记得关注哦~ 题目描述 给你一棵二叉搜索树,请 按中序遍历 将其重新排列为一…

初识RabbitMQ - 安装 - 搭建基础环境

RabbitMQ 各个名词介绍 Broker:接收和分发消息的应用,RabbitMQ Server 就是 Message Broker Virtual host:出于多租户和安全因素设计的,把 AMQP 的基本组件划分到一个虚拟的分组中,类似于网络中的 namespace 概念。当…

使用ffmpeg 压缩视频

我有一批1080p的视频,在网上播放占用空间太大,需要进行压缩以后再上传,下面是记录一下ffmpeg命令的使用情况 原视频大小:288mb --压缩加修改分辨率 640p ffmpeg -y -i C4995.mp4 -vcodec libx264 -crf 18 -s vga C4995\C4995_2.MP4 -y: 强制覆盖 -i :输入文件 -vcodec lib…

整治PPOCRLabel中cv2文件读取问题(更新中)

PPOCRLabel 使用PPOCRLabel对ocr预标注结果进行纠正由于PaddleOCR代码库十分混乱,路径经常乱调pip和代码库的代码(pip库和源码冲突),经常报错,因此paddleocr和ppocrlabel都是使用pip包; 安装 pip install PPOCRLabel2.1.3启动 PPOCRLabel…