加入收藏 | 设为首页 | 会员中心 | 我要投稿 河北网 (https://www.hebeiwang.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 编程 > 正文

Redis的那些最常见面试问题

发布时间:2018-09-06 22:54:24 所属栏目:编程 来源:回首笑人间
导读:9月15日技能沙龙 | 与东华软件、AWS、京东金融、饿了么四位大咖切磋精准运维! 1.什么是redis? Redis 是一个基于内存的高机能key-value数据库。 2.Reids的特点 Redis本质上是一个Key-Value范例的内存数据库,很像memcached,整个数据库完好加载在内存傍边进
副问题[/!--empirenews.page--] 9月15日技能沙龙 | 与东华软件、AWS、京东金融、饿了么四位大咖切磋精准运维!

Redis的那些最常晤口试题目

1.什么是redis?

Redis 是一个基于内存的高机能key-value数据库。

2.Reids的特点

Redis本质上是一个Key-Value范例的内存数据库,很像memcached,整个数据库完好加载在内存傍边举办操纵,按期通过异步操纵把数据库数据flush到硬盘长举办生涯。

由于是纯内存操纵,Redis的机能很是精彩,每秒可以处理赏罚高出 10万次读写操纵,是已知机能最快的Key-Value DB。

Redis的精彩之处不只仅是机能,Redis最大的魅力是支持生涯多种数据布局,另外单个value的最大限定是1GB,不像 memcached只能生涯1MB的数据,因此Redis可以用来实现许多有效的成果。

例如说用他的List来做FIFO双向链表,实现一个轻量级的高性 能动静行列处事,用他的Set可以做高机能的tag体系等等。其它Redis也可以对存入的Key-Value配置expire时刻,因此也可以被看成一 个成果增强版的memcached来用。

Redis的首要弱点是数据库容量受到物理内存的限定,不能用作海量数据的高机能读写,因此Redis得当的场景首要范围在较小数据量的高机能操纵和运算上。

3.行使redis有哪些甜头?

  1. 速率快,由于数据存在内存中,相同于HashMap,HashMap的上风就是查找和操纵的时刻伟大度都是O(1) 
  2. 支持富厚数据范例,支持string,list,set,sorted set,hash 
  3. 支持事宜,操纵都是原子性,所谓的原子性就是对数据的变动要么所有执行,要么所有不执行 
  4. 富厚的特征:可用于缓存,动静,按key配置逾期时刻,逾期后将会自动删除

4.redis对比memcached有哪些上风?

  1. memcached全部的值均是简朴的字符串,redis作为其更换者,支持更为富厚的数据范例 
  2. redis的速率比memcached快许多
  3. redis可以耐久化其数据

5.Memcache与Redis的区别都有哪些?   

存储方法 Memecache把数据所有存在内存之中,断电后会挂掉,数据不能高出内存巨细。 Redis有部份存在硬盘上,这样能担保数据的耐久性。

数据支持范例 Memcache对数据范例支持相对简朴。 Redis有伟大的数据范例。

行使底层模子差异 它们之间底层实现方法 以及与客户端之间通讯的应用协议纷歧样。 Redis直接本身构建了VM 机制 ,由于一样平常的体系挪用体系函数的话,会挥霍必然的时刻去移动和哀求。

6.redis常识趣能题目息争决方案:  

  1. Master写内存快照,save呼吁调治rdbSave函数,会阻塞主线程的事变,当快照较量大时对机能影响长短常大的,会中断性停息处事,以是Master最好不要写内存快照。
  2. Master AOF耐久化,假如不重写AOF文件,这个耐久化方法对机能的影响是最小的,可是AOF文件会不绝增大,AOF文件过大会影响Master重启的规复速率。Master最好不要做任何耐久化事变,包罗内存快照和AOF日记文件,出格是不要启用内存快照做耐久化,假如数据较量要害,某个Slave开启AOF备份数据,计策为每秒同步一次。
  3. Master挪用BGREWRITEAOF重写AOF文件,AOF在重写的时辰会占大量的CPU和内存资源,导致处事load过高,呈现短暂处事停息征象。
  4. Redis主从复制的机能题目,为了主从复制的速率和毗连的不变性,Slave和Master最亏得统一个局域网内

7. mySQL里有2000w数据,redis中只存20w的数据,怎样担保redis中的数据都是热门数据

相干常识:redis 内存数据集巨细上升到必然巨细的时辰,就会施行数据裁减计策(接纳计策)。

redis 提供 6种数据裁减计策:

  1. volatile-lru:从已配置逾期时刻的数据集(server.db[i].expires)中挑选最近起码行使的数据裁减
  2. volatile-ttl:从已配置逾期时刻的数据集(server.db[i].expires)中挑选将要逾期的数据裁减
  3. volatile-random:从已配置逾期时刻的数据集(server.db[i].expires)中恣意选择数据裁减
  4. allkeys-lru:从数据集(server.db[i].dict)中挑选最近起码行使的数据裁减
  5. allkeys-random:从数据集(server.db[i].dict)中恣意选择数据裁减
  6. no-enviction(遣散):榨取遣散数据 

8.请用Redis和恣意说话实现一段恶意登录掩护的代码,限定1小时内每用户Id最多只能登录5次。详细登录函数或成果用空函数即可,不消具体写出。 

用列表实现:列表中每个元素代表登岸时刻,只要最后的第5次登岸时刻和此刻时刻差不高出1小时就榨取登岸.用Python写的代码如下:

  1. #!/usr/bin/env python3  
  2. import redis    
  3. import sys    
  4. import time   
  5.  
  6. r = redis.StrictRedis(host=’127.0.0.1′, port=6379, db=0)   
  7. try:       
  8.    id = sys.argv[1]  
  9. except:    
  10.    print(‘input argument error’)   
  11.    sys.exit(0)    
  12. if r.llen(id) >= 5 and time.time() – float(r.lindex(id, 4)) <= 3600:       
  13.    print(“you are forbidden logining”)  
  14. else:         
  15.    print(‘you are allowed to login’)  
  16.    r.lpush(id, time.time())   
  17.    # login_func() 

9.为什么redis必要把全部数据放到内存中? 

(编辑:河北网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

热点阅读