分布式专题-Redis核心数据结构精讲

devtools/2024/11/22 16:09:14/

1. redis安装:

redis.conf是redis启动配置文件;

redis连接:

数据类型:

redis命令:

String类型:

INCRBY orderId 1000 是 Redis 数据库中的一个命令,用于将存储在键 orderId 中的整数值增加 1000。以下是该命令的详细解释:

  • INCRBY: 这是 Redis 的一个命令,表示 "Increment By",即按指定值增加。
  • orderId: 这是要操作的键,它必须已经存在于 Redis 中,并且其值是一个整数或可以转换为整数的值。
  • 1000: 这是要增加的值,即增量。

具体来说,这个命令会将键 orderId 对应的当前值增加 1000。如果 orderId 当前存储的值是 5000,执行这个命令后,orderId 的值将变为 6000。

INCRBY orderId 1000

假设 orderId 当前的值是 2500,那么执行上述命令后,orderId 的值将变为 3500。

总结来说,INCRBY orderId 1000 命令用于对键 orderId 的值进行增加操作,每次调用都会将该键的值增加 1000。这在需要生成唯一订单号或其他类似场景中非常有用。

Hash类型:

常用场景:

List操作:

BRPOP key timeout 是 Redis 数据库中的一个命令,用于从指定的列表(list)中弹出(移除并返回)最后一个元素。如果列表为空,命令会阻塞直到有元素被推入列表或超时。以下是该命令的详细解释:

  • BRPOP: 这是 Redis 的一个命令,表示 "Blocking Remove from List",即从列表中阻塞地移除元素。
  • key: 这是要操作的键,它必须是一个列表类型的键。
  • timeout: 这是阻塞等待的时间(以毫秒为单位)。如果在指定时间内没有元素被推入列表,命令将返回 nil 并解除阻塞。

具体来说,这个命令会从指定的列表中弹出最后一个元素,并在列表为空时阻塞等待,直到有新元素被添加到列表或达到超时时间。

例如:

BRPOP mylist 5000

这个命令会从名为 mylist 的列表中弹出最后一个元素。如果 mylist 为空,命令将阻塞等待最多 5000 毫秒(5 秒),直到有新元素被添加到 mylist 或超时。

如果 mylist 当前包含元素 [1, 2, 3],执行上述命令后,返回的值将是 3,并且 mylist 将变为 [1, 2]。

如果 mylist 为空,并且在 5000 毫秒内没有新元素被添加,命令将返回 nil

总结来说,BRPOP key timeout 命令用于从指定的列表中阻塞地移除最后一个元素,适用于需要等待某个事件发生的场景,比如消息队列的消费者。

常用场景:

set:

差集:以第一个集合作为基准。

像这种搜索的话,怎么往里加呢?redis中一个list,一个key,多个结果;

zset:

Redis真的是单线程吗?

其他高级命令:


http://www.ppmy.cn/devtools/136052.html

相关文章

庖丁解java(一篇文章学java)

(大家不用收藏这篇文章,因为这篇文章会经常更新,也就是删除后重发) 一篇文章学java,这是我滴一个执念... 当然,真一篇文章就写完java基础,java架构,java业务实现,java业务扩展,根本不可能.所以,这篇文章,就是一个索引,索什么呢? 请看下文... 关于决定开始写博文的介绍…

企业架构框架之银行业参考架构BIAN

本文从业务人员便于理解的角度来介绍 BIAN,与 BIAN 官方对其体系的解释有一定出入,仅供参考。 BIAN ( The Banking Industry Architecture Network) 是一个业界多方协作的非营利性组织,由全球领先银行、技术提供商、顾问和学者组成&#xff…

VUE:基于MVVN的前端js框架

文章目录 vue框架v-show vue框架 注意是 先写函数名,再写function。 handle:function (){}下面是错误的 function:handle(){}3 v-show 本质上等于号后面还是判断条件,所以不能写赋值语句,下面是正确的 下面是错误的 v-show " ge…

【第八课】Rust中的函数与方法

目录 前言 函数指针 函数当作另一个函数的参数 函数当作另一个函数的返回值 闭包 方法 关联函数 总结 前言 在前面几课中,我们都或多或少的接触到了rust中的函数,rust中的函数和其他语言的并没有什么不同,简单的语法不在这篇文章中赘…

11.21 小清新图论专场训练

小清新 A 怎么感觉不是很简单呢 分析一下发现操作的自由度是很高的,不妨认为 一个连通块内不需要考虑边的方向,只需考虑当前是否还有空位 空位的判定条件就是是否已经加出一个环了 int n , L ; int a[N] , b[N] ; int bin[N] ; bool vis[N] ; int F…

React-自定义Hook与逻辑共享

#题引:我认为跟着官方文档学习不会走歪路 在 React 中,自定义 Hook 是一种复用逻辑的方式。自定义 Hook 是一个 JavaScript 函数,名称以 use 开头,可以调用其他的 Hook, 可以返回任意值。 创建自定义Hook 假设你正在开发一款重…

prime算法的运用

确定初始点为初始前驱 每次遍历前驱为已经被访问的点 后继是已被访问点的相邻未被访问的点 是否被访问用标记数组标记 #include<iostream> #include<cmath> #define MaxInt 10000000 #define MVnum 100 using namespace std; int arcs[6][6] {0,6,1,5,MaxInt,…

3.langchain中的prompt模板 (few shot examples in chat models)

本教程将介绍如何使用LangChain库和智谱清言的 GLM-4-Plus 模型来理解和推理一个自定义的运算符&#xff08;例如使用鹦鹉表情符号&#x1f99c;&#xff09;。我们将通过一系列示例来训练模型&#xff0c;使其能够理解和推断该运算符的含义。 环境准备 首先&#xff0c;确保…