第一节 初识Redis

1. 概述

Redis是一个开源的、使用ANSI C语言编写的Key-Value存储系统。Redis的官方名称为Remote Dictionary Server(远程字典服务),它提供了多种语言的API,并且具有高性能、极低延迟和简单性的特点,被广泛用于缓存、会话管理、实时分析等场景。并且可以在 Linux、OSX、OpenBSD、NetBSD、FreeBSD上编译和使用。
Redis官网地址
Redis下载地址

2. Redis的应用场景

  • 缓存:用于存储临时数据以提高系统响应速度。
  • 会话管理:用于存储用户会话数据,如登录信息、购物车等。
  • 实时分析:用于实时统计和分析数据,如实时监控、日志分析等。
  • 消息队列:利用列表或流数据结构实现消息队列功能。
  • 分布式锁:通过设置键的过期时间,实现分布式系统中的锁机制。
  • 排行榜:利用有序集合实现排行榜功能。

3. Redis的部署模式

  • 单节点模式:这是最基本的部署方式,Redis实例单独运行在一个服务器上,处理所有的读写请求。适用于小型项目或测试环境,不具备高可用性和扩展性。
  • 主从模式 (Replication):在这种模式下,数据会在一个主节点(Master)和一个或多个从节点(Slave)之间进行复制。主节点处理写操作,从节点处理读操作,可以实现读写分离和一定程度上的负载均衡。但如果主节点失败,需要手动进行主备切换。
  • 哨兵模式 (Sentinel): 哨兵模式是主从模式的升级版,通过引入Sentinel节点来监控Redis主从集群的状态。Sentinel节点可以自动发现主节点的故障,并触发自动故障转移,提升系统的高可用性。它解决了主从模式中手动故障转移的问题。
  • Cluster模式:Redis Cluster是Redis 3.0版本后引入的分布式集群模式,它使用哈希槽(slot)的概念来分散数据,每个节点存储一部分数据。Cluster模式提供了自动的分区、高可用性以及水平扩展能力。在该模式下,数据被自动分片到不同的主节点上,每个主节点都有若干个从节点作为备份。当某个节点失败时,Cluster能够自动将流量重新导向到其他节点,确保服务的连续性。
相关推荐
雨中飘荡的记忆2 天前
大流量下库存扣减的数据库瓶颈:Redis分片缓存解决方案
java·redis·后端
曲幽2 天前
FastAPI分布式系统实战:拆解分布式系统中常见问题及解决方案
redis·python·fastapi·web·httpx·lock·asyncio
知我Deja_Vu7 天前
redisCommonHelper.generateCode(“GROUP“),Redis 生成码方法
数据库·redis·缓存
Charlie_lll7 天前
Redis脑裂问题处理——基于min-replicas-to-write配置
redis·后端
奇点爆破XC7 天前
Redis迁移
数据库·redis·bootstrap
断手当码农7 天前
Redis 实现分布式锁的三种方式
数据库·redis·分布式
菜鸟小九7 天前
redis原理篇(基本数据结构)
数据结构·数据库·redis
没有bug.的程序员7 天前
电商秒杀系统深度进阶:高并发流量建模、库存零超卖内核与 Redis+MQ 闭环
数据库·redis·缓存·高并发·电商秒杀·流量建模·库存零超卖
菜鸟小九7 天前
redis原理篇(五种数据结构)
数据结构·数据库·redis
初次攀爬者7 天前
Redis分布式锁实现的三种方式-基于setnx,lua脚本和Redisson
redis·分布式·后端