Redis详解包含:B站面试问题及详解

Posted 一马什么梅一

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Redis详解包含:B站面试问题及详解相关的知识,希望对你有一定的参考价值。

前言:

什么是NoSql
为了解决高并发、高可扩展、高可用、大数据存储问题而产生的数据库解决方案,就是NoSql数据库。
NoSQL,泛指非关系型的数据库,NoSQL即Not-Only SQL,它可以作为关系型数据库的良好补充。但
是它不能替代关系型数据库,而且它是存储在内存中,所以它的访问速度很快。

Nosql的数据库分类

键值(Key-Value)存储数据库

相关产品: Tokyo Cabinet/Tyrant、Redis、Voldemort、Berkeley DB

典型应用:内容缓存,主要用于处理大量数据的高访问负载。

数据模型:一系列键值对

优势:快速查询
劣势:存储的数据缺少结构化

列存储数据库

相关产品:Cassandra, HBase, Riak

典型应用:分布式的文件系统

数据模型:以列簇式存储,将同一列数据存在文件系统中

优势:查找速度快,可扩展性强,更容易进行分布式扩展
劣势:功能相对局限

文档型数据库

相关产品:CouchDB、MongoDB

典型应用:Web应用(与Key-Value类似,Value是结构化的)

数据模型:一系列键值对

优势:数据结构要求不严格
劣势:查询性能不高,而且缺乏统一的查询语法

图形(Graph)数据库

相关数据库:Neo4J、InfoGrid、Infinite Graph

典型应用:社交网络

数据模型:图结构

优势:利用图结构相关算法。
劣势:需要对整个图做计算才能得出结果,不容易做分布式的集群方案。

Redis发展简史

2008年,意大利的一家创业公司Merzia推出了一款基于mysql的网站实时统计系统LLOOGG,然而没过多久该公司的创始人 Salvatore Sanfilippo便对MySQL的性能感到失望,于是他决定亲自为LLOOGG量身定做一个数据库,并于2009年开发完成,这个数据库就是Redis。

不过Salvatore Sanfilippo并不满足只将Redis用于LLOOGG这一款产品,而是希望更多的人使用它,于是在同一年Salvatore Sanfilippo将Redis开源发布,并开始和Redis的另一名主要的代码贡献者Pieter Noordhuis一起继续着Redis的开发,直到今天。

SalvatoreSanfilippo自己也没有想到,短短的几年时间,Redis就拥有了庞大的用户群体。HackerNews在2012年发布了一份数据库的使用情况调查,结果显示有近12%的公司在使用Redis。国内如新浪微博、街旁网、知乎网,国外如GitHub、Stack Overflow、Flickr等都是Redis的用户。

VMware公司从2010年开始赞助Redis的开发,Salvatore Sanfilippo和Pieter Noordhuis也分别在3月和5月加入VMware,全职开发Redis。

Redis介绍

Redis是用C语言开发的一个开源的高性能键值对(key-value)数据库。它通过提供多种键值数据类型来适应不同场景下的存储需求,目前为止Redis支持的键值数据类型如下:

  • 字符串类型
  • 散列类型
  • 列表类型
  • 集合类型
  • 有序集合类型

Redis应用场景

缓存(数据查询、短连接、新闻内容、商品内容等等)。(最多使用)

分布式集群架构中的session分离。

聊天室的在线好友列表。

任务队列。(秒杀、抢购、12306等等)

应用排行榜。

网站访问统计。

数据过期处理(可以精确到毫秒)

Redis的特性

redis数据访问速度快(数据在内存中)

redis有数据持久化机制(持久化机制有两种:

  1. 定期将内存数据dump到磁盘;
  2. aof(appendonly file)持久化机制——用记日志的方式记录每一条数据更新操作,一旦出现灾难事件,可以通过 日志重放来恢复整个数据库)

redis支持集群模式(容量可以线性扩展)

redis相比其他缓存工具(ehcach/memcached),有一个鲜明的优势:支持丰富的数据结构

Redis安装

  1. 下载Redis
    官网地址:<httpRedis.assets//redis.io/>
    中文官网:http://www.redis.cn/
    下载地址:httpRedis.assets//download.redis.io/releases/redis-3.0.0.tar.gz

  2. Redis安装环境
    Redis安装一般会在Linux系统下进行安装,又因为redis是使用c语言开发,所以需要c语言环境。
    Linux:centOS
    VMware:10
    C语言环境:

  3. Redis安装
    第一步:在VMware中安装CentOS系统(Linux)。
    第二步:在Linux系统中安装c语言环境

     yum install gcc-c++
    

    第三步:将redis的源码包上传到Linux系统。

    第四步:解压源码包
    第五步:进入redis-3.3.3包,然后执行make命令,编译redis的源码

     [root@redis01 redis-3.0.0]# make
    

    第六步:安装

     [root@redis01redis-3.0.0]# make install PREFIX=/usr/local/redis
    

Redis启动

前端启动

前端启动,如果客户端关掉或者执行ctrl+c命令。则整个redis服务也停掉。
前端启动,即在客户端中执行以下命令:

	[root@redis01 bin]# ./redis-server


关闭:ctrl+c

后端启动

第一步:执行cp命令将redis解压缩包中的redis.conf文件拷贝到bin目录下

第二步:修改redis.conf文件:

第三步:启动redis服务

关闭:正常关闭

非正常关闭

Redis支持的数据类型

字符串(String)、散列(Hash)、列表(List)、集合(Set)、有序集合(Sort Set)

这些数据都支持push/pop/add/remove等操作

Redis应用场景

1.缓存(数据查询,短连接,新闻内容,商品内容) (使用最多的)
2.分布式计算框架中Seesion分离
3.聊天室在线好友列表
4.任务对象(秒杀,12306购票)
5.应用排行榜
6.网站访问统计
7.数据过期处理(可以精确到毫秒)

Redis作用:
Ø 高性能共享:当数据需要被多个不同线程/进程/节点频繁读取时,redis基于内存读写效率高;
Ø 并发缓冲:当多个写请求需要连接其它数据库时,使用redis做一个缓冲,将多个并发连接转化为一次连接;

Redis可能出现的问题

Redis缓存击穿

什么是缓存击穿
由于高并发请求刚好失效的key或黑客攻击导致,后端大量请求redis中不存在的key,一般业务程序在redis不存在缓存时会到数据库中查询,因此这种情况就会导致数据库瞬间并发大量连接,造成数据库崩溃。

解决方案:

1.为mysql各表的key设置布隆过滤器,请求mysql前先用布隆过滤器确认一遍,存在才申请(防黑客)

2.使用互斥锁,缓存不存在时向数据库发起带锁的读取请求,其他并发请求获取不到锁则休眠重试读取(防止并发失败)

Redis缓存雪崩

什么是缓存击穿

缓存在同一时间大面积失效,此时大量请求失效key,造成数据库高并发连接崩溃。

解决方案:

1.缓存预热:根据大数据统计结果提前缓存热]数据(防初启动)
2.同样采用互斥锁
3.过期时间追加随机值

Redis的持久化方式

RDB持久化(默认持久化方式),每达到持久化的条件时(例如:10秒进行一次持久化),就会将Redis内存中的数据固化到磁盘上的RDB文件中

RDB用来做数据持久化,一旦Redis异常退出,就会丢失最后一次快照以后更改的所有数据,这样一来就会出现数据丢失问题

AOF持久化,将用户的操作通过文件记录下来,由于每次写操作都会记录日志,因此AOF会降低性能,但比起RDB的一次性阻塞式备份数据,AOF消耗的内存和资源更少。

什么时候开启这个机制?

数据很重要以至于无法承受任何数据损失,可以考虑开启AOF

开启AOF需要修改Redis的redis.conf文件

1.需要在redis.conf文件中查找到当前属性
appendonly no
修改属性值为yes 即
appendonly yes

2.在属性的下面有文件的默认名称
appendfilename “appendonly.aof”

Jedis连接集群

public static void main(String[] args) { 
//节点设置 
HashSet<HostAndPort> nodes = new HashSet<>(); 
nodes.add(new HostAndPort("node01", 7001)); 
nodes.add(new HostAndPort("node02", 7002)); 
nodes.add(new HostAndPort("node03", 7003)); 
nodes.add(new HostAndPort("node04", 7004)); 
nodes.add(new HostAndPort("node05", 7005)); 
nodes.add(new HostAndPort("node06", 7006)); 
//创建JedisCluster实例 
JedisCluster cluster = new JedisCluster(nodes); 
cluster.set("ruhua", "rightgirl");
String s = cluster.get("ruhua"); 
System.out.println(s); 
cluster.close(); 
}

Redis常用命令有哪些

Redis字节面试题

第一:聊聊你对 Redis 分布式锁的理解。
第二:Redis 持久化是如何工作的?Redis在持久化过程中和可以对外服务么?如果可以的话,Redis又是如何处理新命令的?
第三:Redis 内存不够时间,如何处理新的请求?Redis 是如何处理过期数据的
第四:Redis 有序数据结构zset底层原理有了解过么?
第五:Redis 位图应用场景及实现原理可以讲一下么?
第六:Redis 的缓存穿透/缓存雪崩/缓存重建/这类问题,可以讲讲么
第七:Redis 集群分片原理是怎样的?
第八:Redis 单线程和Redis6.0 的多线程是如何工作的?

有收获?希望烙铁们来个三连击,让更多的同学看到这篇文章

1、烙铁们,关注我看完保证有所收获,不信你打我。

2、点个赞呗,可以让更多的人看到这篇文章,后续还会有很哇塞的产出。

本文章仅供学习及个人复习使用,如需转载请标明转载出处,如有错漏欢迎指出
务必注明来源(注明: 来源:csdn , 作者:-马什么梅-)

以上是关于Redis详解包含:B站面试问题及详解的主要内容,如果未能解决你的问题,请参考以下文章

视频+图文+动画详解冒泡排序

XSS漏洞详解

(转) Java中的负数及基本类型的转型详解

详解Redis 主从复制及主从复制原理

大厂面试题详解:如何用Redis实现分布式锁?

69个经典Java面试题和答案详解,附相关架构及资料