分布式专题-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真的是单线程吗?

其他高级命令:

相关推荐
梦想平凡32 分钟前
PHP 微信棋牌开发全解析:高级教程
android·数据库·oracle
TianyaOAO42 分钟前
mysql的事务控制和数据库的备份和恢复
数据库·mysql
Ewen Seong1 小时前
mysql系列5—Innodb的缓存
数据库·mysql·缓存
节点。csn1 小时前
Hadoop yarn安装
大数据·hadoop·分布式
码农老起1 小时前
企业如何通过TDSQL实现高效数据库迁移与性能优化
数据库·性能优化
夏木~2 小时前
Oracle 中什么情况下 可以使用 EXISTS 替代 IN 提高查询效率
数据库·oracle
W21552 小时前
Liunx下MySQL:表的约束
数据库·mysql
黄名富3 小时前
Redis 附加功能(二)— 自动过期、流水线与事务及Lua脚本
java·数据库·redis·lua
NiNg_1_2343 小时前
基于Hadoop的数据清洗
大数据·hadoop·分布式
言、雲3 小时前
从tryLock()源码来出发,解析Redisson的重试机制和看门狗机制
java·开发语言·数据库