redis相关

 
  1. redis是单线程的,因此在多核的机器上可以开多个redis,提高服务器性能利用率。
  2. redis有主从复制机制,通常用于提高读写数据性能。从redis服务器会定时向主redis服务器请求数据同步。
  3. redis存在set队列,可以去除重复的记录。
  4. redis存在自动排序队列,可以设定记录的排序权重来进行排序。
  5. redis有两种数据存储方式:
    1. 快照方式:redis定时把内存中的数据全部写到硬盘上。
    2. VM方式:redis把访问量大的数据(所在的页面)放在内存里,把访问量小的数据放到磁盘上。(目前不是很稳定)
  1. redis存储数据,单条记录越长,内存利用率就越高。
    1. 经测试,字节数在300以上,内存利用率已经达到95%以上。

 

  1. redis性能

软件:单个redis服务。

操作系统:VM虚机+ubuntu8.04

VM硬件指标:

         内存:768M

         CPU

                   品牌:intel i5

                   频率:2.66GHZ

核数:单核

性能指标如下(单条记录长度:1024):

         写记录:46948/

         读记录:52083/

         在普通队列中插入元素:43478/

         在普通队列中弹出元素:47619/

         set(唯一)队列中添加元素:50761/

         set(唯一)队列中弹出元素:46511/

  1. 缺点
    1. redis服务受到压力过大时,其他客户端访问redis服务会没有任何响应(得不到返回)。

 

官方文档:

redis源码doc目录中的所有文档

官方网站:http://redis.io/

命令集合:http://redis.io/commands

国外分析文档:

redis-from-the-ground-up:

http://blog.mjrusso.com/2010/10/17/redis-from-the-ground-up.html

 Redis: under the hood

http://pauladamsmith.com/articles/redis-under-the-hood.html

redis cookbook:http://www.rediscookbook.org/

redis tutorial:

http://simonwillison.net/static/2010/redis-tutorial/

Redis Virtual Memory: the story and the code:

http://antirez.com/post/redis-virtual-memory-story.html

redis性能测试:

http://jaksprats.wordpress.com/2010/09/22/12/

一些中文文档:

概述性的介绍了redis的特点和使用:

http://www.cnblogs.com/xhan/archive/2011/02/08/1949867.html

 

读Redis有感:

http://blog.csdn.net/gpcuster/archive/2010/10/21/5956555.aspx

Redis误区

http://timyang.net/data/redis-misunderstanding/

Redis内存陷阱

http://www.javaeye.com/topic/808293

接下来的分析主要基于2.0.4,我是从去年11月份开始学习这个代码的,那时的稳定版本还是2.0.4的,没想到,才不到半年时间,就升到了2.2.4,代码结构也有了很大的变化,原来2.0.4一个redis.c文件有11000行代码,像aof、rdb、vm等功能都集成到这一个文件里,当时看起来真费劲,不过之后作者把这些功能分开了,放到不同的文件里了。不过功能还没有太大的变化,还是可以借鉴的。

备注:我将一些文章中的代码着色后会使得文章超过baidu空间中的字数限制,这就迫使我寻求其他方法。最后在redice的帮助下,利用他的主机搭建了一个个人blog,在此谢过redice。所有文章仅在个人blog进行后续更新,baidu空间仅作为一个备份。

Redis相关的面试题涵盖了以下几个方面: 1. Redis的基本概念和特性:面试官可能会问到你对Redis的理解和熟悉程度。你可以回答Redis是一个开源的内存键值存储系统,具有高性能和持久化能力。它支持多种数据结构,如字符串、哈希表、列表、集合和有序集合等。 2. Redis的数据持久化方式:Redis提供了两种方式来将数据持久化到磁盘上,分别是RDB(Redis Database)和AOF(Append Only File)。RDB是一种快照方式,可以将数据以二进制形式保存到硬盘上,而AOF则是将每个写操作追加到文件末尾。你可以解释一下这两种方式的优缺点,并说明在不同场景下应该选择哪种方式。 3. Redis的线程模型:在Redis 6.0之前,Redis是单线程的。而在Redis 6.0之后开始支持多线程。Redis内部使用基于epoll的多路复用来处理网络IO,而执行命令的核心模块仍然是单线程的。你可以简要介绍一下Redis的线程模型以及引入多线程的原因。 4. Redis的扩展模块:Redis支持通过扩展模块来增加额外的功能。例如,BloomFilter、RedisSearch和Redis-ML等扩展模块可以用于实现不同的功能需求。你可以提到一些常用的Redis扩展模块,并解释一下它们的作用和用途。 总结起来,面试中关于Redis的问题主要包括对Redis的基本概念和特性的理解、数据持久化方式、线程模型以及扩展模块的使用等方面。通过对这些问题的了解和回答,可以展示出你对Redis的熟悉程度和实际应用能力。同时,你还可以结合自己的经验和实际项目,给出一些实际的应用场景和解决方案,从而更好地回答面试官的问题。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* [面试 Redis 没底?这 40 道面试题让你不再慌(附答案)](https://blog.csdn.net/xmt1139057136/article/details/115423283)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *3* [redis面试题总结(附答案)](https://blog.csdn.net/guorui_java/article/details/117194603)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值