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

  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真的是单线程吗?

其他高级命令:

相关推荐
花好月圆春祺夏安11 分钟前
基于odoo17的设计模式详解---备忘模式
数据库·设计模式
有想法的py工程师39 分钟前
PostgreSQL 查询库中所有表占用磁盘大小、表大小
数据库·postgresql
文艺倾年2 小时前
【八股消消乐】浅尝Kafka性能优化
分布式·性能优化·kafka
R_AirMan2 小时前
深入浅出Redis:一文掌握Redis底层数据结构与实现原理
java·数据结构·数据库·redis
Hello.Reader2 小时前
RedisJSON 内存占用剖析与调优
数据库·redis·缓存
钟琛......2 小时前
Redisson 的分布式锁
分布式
wkj0013 小时前
php 如何通过mysqli操作数据库?
android·数据库·php
九皇叔叔5 小时前
【9】PostgreSQL 之 vacuum 死元组清理
数据库·postgresql
风雅的远行者5 小时前
mysql互为主从失效,重新同步
数据库·mysql
晨岳5 小时前
CentOS 安装 JDK+ NGINX+ Tomcat + Redis + MySQL搭建项目环境
java·redis·mysql·nginx·centos·tomcat