缓存—Redis

本文涉及的产品
Redis 开源版,标准版 2GB
推荐场景:
搭建游戏排行榜
简介: 谈及缓存,在软件开发时经常用到缓存是Redis,算是使用最广法的缓存中间件。当然,在面试的过程中,Redis也是经常被询问的题目

谈及缓存,在软件开发时经常用到缓存是Redis,算是使用最广法的缓存中间件。

当然,在面试的过程中,Redis也是经常被询问的题目

Redis是单线程吗?

redis的单线程,是指Redis的网络I/O线程,以及键值的SET和GET等读写操作都由一个线程完成

但是,在Redis持久化、集群同步等操作,是由其他线程来执行

Redis单线程为什么快?

  • Redis的大部分操作都是在内存中完成
  • 采用了高效的数据结构,比如Hash、跳表
  • 单线程模型,避免了多线程间切换的产生的其他时间和性能开销
  • 单线程模型,也不用去考虑因多线程导致死锁的问题
  • Redis采用了I/O多路复用机制处理大量的客户端Socket请求,使得Redis更高效进行网络通信(重要因素)

注意点:

Redis 4.0版本后,增加多线程支持,主要体现在大数据的异步删除功能

Redis 6.0版本后,新增多线程I/O的读写并发能力(即采用了多个I/O线程来处理网络请求)

Redis持久化

面试时,经常会被提问:如何保持数据不丢失?其主要是考察Redis持久化问题,如何去做持久化?

什么情况Redis数据会丢失?

缓存数据在内存中,如果服务器重启时,内存中的数据就会丢失。为了保证数据不丢失,将数据存储到磁盘中,以便服务器重启后,能够从磁盘中恢复原有的数据。

持久化的三种方式:

  • AOF日志(Append only File 文件追加方式):记录所有的操作命令,并以文本形式追加到文件中
  • RDB快照(Redis DataBase):将某时刻的内存数据,以二进制形式写入磁盘
  • 混合持久化方式:redis4.0版本后新增的混合持久化方式

Redis 数据类型

基础数据类型

String

  • 常用命令:set/get/decr/incr/mget
  • 使用场景:普通的key/value存储

Hash

  • 常用命令:hget/hset/hgetall
  • 使用场景:存储某对象数据

List

  • 常用命令:lpush/rpush/lpop/rpoplrange
  • 使用场景:存储列表数据(如微博关注列表/粉丝列表等)

Set(集合)

  • 常用命令:sadd/spop/smembers/sunion等
  • 使用场景:Redis set对外提供的功能与list类似是一个列表的功能,特殊之处在于set是可以自动排重的,当你需要存储一个列表数据,又不希望出现重复数据时,set是一个很好的选择,并且set提供了判断某个成员是否在一个set集合内的重要接口,这个也是list所不能提供的

Sorted set(有序集合)

  • 常用命令:zadd/zrange/zrem/zcard等
  • 使用场景:和set一样,但是有序集合通过用户额外提供一个优先级score的参数来为成员排序,并且插入也是有序

特殊数据类型(进阶)

Bitmap 位图

  • 使用方法:

    • setbit key index 0/1 设置某位的值
    • getbit key index 获取某位的值
    • bitcount key start end 获取指定范围内为1的数量
  • 使用场景:统计用户一年活跃天数

GeoHash地理位置

  • 使用方法:

    • geoadd key longitude latitude element(后面可配置多个三元组) 添加元素
    • geodist key element1 element2 unit 计算两个元素的距离
    • geopos key element [element] 获取元素的位置
    • geohash key element 获取元素hash
  • 使用场景:常用于计算附近的人,附近商店

HyperLogLog 基数统计

  • 使用方法:

    • pfadd key element 添加
    • pfcount key 计算
    • pfmerge destkey sourcekey1 sourcekey2 ... 合并
  • 使用场景:提供不精确的去重技术方案

bloomFilter布隆过滤器

  • 使用方法

    • bf.add key element 添加
    • bf.exists key element 判断是否存在
    • bf.madd key element1 element2 ... 批量添加
    • bf.mexists key element1 element2 ... 批量判断
  • 使用场景:网站去重,垃圾邮件过滤,缓存穿透
目录
相关文章
|
6月前
|
缓存 NoSQL 关系型数据库
美团面试:MySQL有1000w数据,redis只存20w的数据,如何做 缓存 设计?
美团面试:MySQL有1000w数据,redis只存20w的数据,如何做 缓存 设计?
美团面试:MySQL有1000w数据,redis只存20w的数据,如何做 缓存 设计?
|
1月前
|
缓存 负载均衡 监控
135_负载均衡:Redis缓存 - 提高缓存命中率的配置与最佳实践
在现代大型语言模型(LLM)部署架构中,缓存系统扮演着至关重要的角色。随着LLM应用规模的不断扩大和用户需求的持续增长,如何构建高效、可靠的缓存架构成为系统性能优化的核心挑战。Redis作为业界领先的内存数据库,因其高性能、丰富的数据结构和灵活的配置选项,已成为LLM部署中首选的缓存解决方案。
|
2月前
|
存储 缓存 NoSQL
Redis专题-实战篇二-商户查询缓存
本文介绍了缓存的基本概念、应用场景及实现方式,涵盖Redis缓存设计、缓存更新策略、缓存穿透问题及其解决方案。重点讲解了缓存空对象与布隆过滤器的使用,并通过代码示例演示了商铺查询的缓存优化实践。
164 1
Redis专题-实战篇二-商户查询缓存
|
1月前
|
缓存 运维 监控
Redis 7.0 高性能缓存架构设计与优化
🌟蒋星熠Jaxonic,技术宇宙中的星际旅人。深耕Redis 7.0高性能缓存架构,探索函数化编程、多层缓存、集群优化与分片消息系统,用代码在二进制星河中谱写极客诗篇。
|
6月前
|
缓存 NoSQL Java
Redis+Caffeine构建高性能二级缓存
大家好,我是摘星。今天为大家带来的是Redis+Caffeine构建高性能二级缓存,废话不多说直接开始~
894 0
|
2月前
|
缓存 NoSQL 关系型数据库
Redis缓存和分布式锁
Redis 是一种高性能的键值存储系统,广泛用于缓存、消息队列和内存数据库。其典型应用包括缓解关系型数据库压力,通过缓存热点数据提高查询效率,支持高并发访问。此外,Redis 还可用于实现分布式锁,解决分布式系统中的资源竞争问题。文章还探讨了缓存的更新策略、缓存穿透与雪崩的解决方案,以及 Redlock 算法等关键技术。
|
6月前
|
消息中间件 缓存 NoSQL
基于Spring Data Redis与RabbitMQ实现字符串缓存和计数功能(数据同步)
总的来说,借助Spring Data Redis和RabbitMQ,我们可以轻松实现字符串缓存和计数的功能。而关键的部分不过是一些"厨房的套路",一旦你掌握了这些套路,那么你就像厨师一样可以准备出一道道饕餮美食了。通过这种方式促进数据处理效率无疑将大大提高我们的生产力。
228 32
|
存储 缓存 NoSQL
Spring Boot2.5 实战 MongoDB 与高并发 Redis 缓存|学习笔记
快速学习 Spring Boot2.5 实战 MongoDB 与高并发 Redis 缓存
Spring Boot2.5 实战 MongoDB 与高并发 Redis 缓存|学习笔记
|
缓存 NoSQL 安全
6.0Spring Boot 2.0实战 Redis 分布式缓存6.0|学习笔记
快速学习6.0Spring Boot 2.0实战 Redis 分布式缓存6.0。
511 0
6.0Spring Boot 2.0实战 Redis 分布式缓存6.0|学习笔记
|
缓存 NoSQL Redis
首页数据显示-添加 redis 缓存(3)| 学习笔记
快速学习 首页数据显示-添加 redis 缓存(3)
241 0
首页数据显示-添加 redis 缓存(3)| 学习笔记