Redis 服务器是一个事件驱动程序,服务器需要处理两类事件:
文件事件(file event)- Redis 服务器通过套接字(Socket)与客户端或者其它服务器进行通信,文件事件就是对套接字操作的抽象。服务器与客户端(或其他的服务器)的通信会产生文件事件,而服务器通过监听并处理这些事件来完成一系列网络通信操作。时间事件(time event)- Redis 服务器有一些操作需要在给定的时间点执行,时间事件是对这类定时操作的抽象。关键词:
文件事件、时间事件
- Java213
- 数据库114
- 分布式83
- 设计80
- 框架74
- JavaCore65
- Spring63
- 笔记52
- 工具50
- 大数据32
- 分布式通信30
- 设计模式28
- Spring核心24
- 架构23
- 搜索引擎数据库22
- DevOps21
- 关系型数据库21
- 软件20
- 网络19
- KV数据库19
- Redis18
- MQ18
- 算法17
- 分布式协同16
- Elasticsearch16
- 操作系统15
- 列式数据库15
- 分布式理论15
- MySQL15
- 综合14
- 面试13
- 基础特性13
- HBase13
- 编程12
- 文档数据库12
- Linux11
- IO11
- 并发11
- MongoDB11
- Spring数据10
- Kafka10
- 中间件9
- Flink9
- Hive9
- JVM9
- 其他9
- 安全9
- 构建9
- 工作8
- 服务器8
- 编程语言8
- 解决方案8
- 分布式存储8
- SpringWeb8
- 重构7
- 分布式调度7
- 容器7
- 高级特性7
- ZooKeeper7
- Maven7
- JavaWeb6
- 网络分层6
- 网络协议6
- 分布式治理6
- Tomcat6
- 监控诊断6
- Python6
- Nginx6
- Hadoop5
- 缓存5
- 测试5
- 微服务5
- Docker5
- Elastic5
- RPC5
- UML4
- 数据库综合4
- 网络技术4
- 术4
- 模板引擎4
- ORM4
- IDE4
- SpringIO4
- Spring其他4
- Spring综合4
- Spring集成4
- RocketMQ4
- 软件工程3
- 编程范式3
- 数据库中间件3
- Git3
- Kubernetes3
- 流量控制2
- JavaBean2
- 人工智能1
- 器1
- 法1
- KV 数据库1
- Spring安全1
关键词:
Pipeline
Pipeline 简介
Redis 是一种基于 C/S 模型以及请求/响应协议的 TCP 服务。通常情况下,一个 Redis 命令的请求、响应遵循以下步骤:
- 客户端向服务端发送一个查询请求,并监听 Socket 返回(通常是以阻塞模式,等待服务端响应)。
- 服务端处理命令,并将结果返回给客户端。
显然,如果每个 Redis 命令都发起一次请求、响应,会很低效。因此,Redis 客户端提供了一种批量处理技术,即
Redis 发布订阅 (pub/sub) 是一种消息通信模式:发送者 (pub) 发送消息,订阅者 (sub) 接收消息。Redis 客户端可以订阅任意数量的频道。
Redis 有两种发布订阅模式
- 基于频道(Channel)的发布订阅
- 基于模式(Pattern)的发布订阅
关键词:
订阅、SUBSCRIBE、PSUBSCRIBE、PUBLISH、观察者模式
📖 内容
Redis
- Redis 基本数据类型 - 关键词:
String、Hash、List、Set、Zset - Redis 高级数据类型 - 关键词:
BitMap、HyperLogLog、Geo、Stream - Redis 数据结构 - 关键词:
对象、SDS、链表、字典、跳表、整数集合、压缩列表 - Redis 内存管理 - 关键词:
定时删除、惰性删除、定期删除、LRU、LFU - Redis 持久化 - 关键词:
RDB、AOF、SAVE、BGSAVE、appendfsync - Redis 事件 - 关键词:
文件事件、时间事件 - Redis 复制 - 关键词:
SLAVEOF、SYNC、PSYNC、命令传播、心跳 - Redis 哨兵 - 关键词:
高可用、监控、选主、故障转移、Raft - Redis 集群 - 关键词:
高可用、监控、选主、故障转移、分区、Raft、Gossip - Redis 订阅 - 关键词:
订阅、SUBSCRIBE、PSUBSCRIBE、PUBLISH、观察者模式 - Redis 独立功能 - 关键词:
事务、ACID、MULTI、EXEC、DISCARD、WATCH - Redis 管道 - 关键词:
Pipeline - Redis 脚本 - 关键词:
Lua - Redis 运维 - 关键词:
安装、配置、命令、集群、客户端 - Redis 实战 - 关键词:
缓存、分布式锁、布隆过滤器 - Redis 面试 💯
- Redis 面试之应用篇 💯

关键词:
定时删除、惰性删除、定期删除、LRU、LFU
Redis 过期删除
Redis 可以为每个键设置过期时间,当键过期时,会自动删除该键。
设置键的生存时间或过期时间
Redis 中,和键的生存时间相关的命令如下所示:
| 命令 | 描述 |
|---|---|
EXPIRE |
设置 key 的过期时间,单位为秒 |
PEXPIRE |
设置 key 的过期时间,单位为毫秒 |
EXPIREAT |
设置 key 的过期时间为指定的秒级时间戳 |
PEXPIREAT |
设置 key 的过期时间为指定的毫秒级时间戳 |
TTL |
返回 key 的剩余生存时间,单位为秒 |
PTTL |
返回 key 的剩余生存时间,单位为毫秒 |
PERSIST |
移除 key 的过期时间,key 将持久保持 |

关键词:
对象、SDS、链表、字典、跳表、整数集合、压缩列表
SDS
SDS 简介
SDS 是 Simple Dynamic String 的缩写,即简单动态字符串。Redis 为 SDS 做了一些优化,以替代 C 字符串来表示字符串内容。此外,SDS 还被 Redis 用作缓冲区(buffer),如:AOF 模块中的 AOF 缓冲区;客户端状态中的输入缓冲区。
Memcached 简介
Memcached 是一个自由开源的,高性能,分布式内存对象缓存系统。
Memcached 是一种基于内存的 key-value 存储,用来存储小块的任意数据(字符串、对象)。这些数据可以是数据库调用、API 调用或者是页面渲染的结果。
Memcached 简洁而强大。它的简洁设计便于快速开发,减轻开发难度,解决了大数据量缓存的很多问题。它的 API 兼容大部分流行的开发语言。本质上,它是一个简洁的 key-value 存储系统。
Memcached 特性
memcached 作为高速运行的分布式缓存服务器,具有以下的特点。


Redis 2.8 版本,新增了哨兵模式,以支持“自动故障转移”,它是 Redis 的 HA 方案。
Redis 哨兵模式由一个或多个 Sentinel 实例组成 Sentinel 集群,可以监控任意多个主服务器,以及这些主服务器的所有从服务器;并在被监视的主服务器进入下线状态时,自动将下线主服务器的某个从服务器升级为新的主服务器,然后由新的主服务器代替已下线的主服务器继续处理命令请求。
关键词:
高可用、监控、选主、故障转移、Raft

在 Redis 中,可以通过执行
SLAVEOF命令或设置slaveof选项,让一个服务器去复制(replicate)另一个服务器,其中,后者叫主服务器(master),前者叫从服务器(slave)。Redis 2.8 以前的复制不能高效处理断线后重复制的情况,而 Redis 2.8 新添的部分重同步可以解决这个问题。
关键词:
SLAVEOF、SYNC、PSYNC、命令传播、心跳