Redis常见面试题--基础篇

问:你了解redis数据库吗?

答:redis数据库是一种非关系型数据库,它的数据存储采用key-value形式,整个数据库的加载都在内存当中,因此它的速度非常快。

问:你知道redis为什么这么快吗?

redis采用内存存储,因此读写速度非常快,没有IO开销。并且redis采用单线程+IO多路复用,在保证线程安全的情况下将速度提升到最佳。

问:我们为什么要使用redis?

答:redis可以作为缓存中间件,我们可以将数据库中频繁访问的数据存放到redis中,用户在访问的时候直接走redis返回,降低数据库的并发量,不仅提高数据库的安全同时提高了系统的性能。

问:redis可以用来干什么?

  • 做缓存中间件
  • 排行榜:redis中提供了有序集合的数据结构---sort set,可以实现排行榜。
  • 计数器:redis提供了incr命令来实现计数器功能,性能非常好,还不用去频繁操作数据库。
  • 分布式会话:集群模式下,在应用不多的情况下一般使用容器自带的session复制功能就能满足,当应用增多相对复杂的系统中,一般都会搭建以Redis等内存数据库为中心的session服务,session不再由容器管理,而是由session服务及内存数据库管理。
  • 分布式锁:在高并发环境下可以利用redis中提供的setnx来实现分布式锁,返回1说明获取锁成功。
  • 最新列表:Redis列表结构,LPUSH可以在列表头部插入一个内容ID作为关键字,LTRIM可用来限制列表的数量,这样列表永远为N个ID,无需查询最新的列表,直接根据ID去到对应的内容页即可。
  • 消息系统:Redis提供了发布/订阅及阻塞队列功能,能实现一个简单的消息队列系统。

问:redis的数据类型有哪些?

  • string
  • hash
  • list
  • set
  • soetset
  • bitmap
  • Hyperloglog:
  • Geospatial

下篇:redis常见面试题-CSDN博客

相关推荐
yyuuuzz6 小时前
谷歌云基础服务的入门认知
linux·运维·服务器·数据库·人工智能·github
落木萧萧8257 小时前
MyBatisGX 批量操作:比 MyBatis-Plus 和 MyBatis-Flex 更好用、更快
mybatis·orm
超梦dasgg7 小时前
工作中 MySQL 读写分离主从延迟:成因、影响、落地方案、生产实战处理
数据库·mysql
Wonderful U7 小时前
Python+Django实战:打造智能生鲜果蔬进销存管理系统(采购入库、库存预警、销售开单、毛利统计)
数据库·python·django
Demon1_Coder7 小时前
Day4-微服务-Seata默认事务
java·数据库·微服务
我是大猴子7 小时前
Redis为什么不适合做持久化和DB的区别在哪里
数据库·redis·缓存
huipeng9267 小时前
企业级微服务开发实战(二):微服务基础设施搭建与中间件部署
java·redis·mysql·spring cloud·微服务·nacos·rabbitmq
mN9B2uk177 小时前
数据库锁总结
数据库·oracle
Jabes.yang7 小时前
Java电商订单系统面试全流程解析:接口设计、数据库、微服务与分布式事务实战
java·微服务·mybatis·分布式事务·电商·订单系统·接口设计
闪电悠米7 小时前
黑马点评-秒杀优化-04_lua_and_db_fallback
服务器·开发语言·网络·数据库·缓存·junit·lua