redis源码分析笔记1-简介和性能

最近本人计划将redis源码完整的分析一遍。又一个伟大的计划开始了。截止到目前有三个伟大的计划在本博客上并行。

  • 整理出一版mysql的复习笔记。目前已经整理了一多半,将逐渐在本博客上发表。
  • 将经典的数据结构与算法100题,每道都做一遍,并测试一遍。目前做到了20题。持续更新。
  • 将redis源码整个分析一遍。目前刚进行到10%左右。
    真是路漫漫其修远兮啊…

前言
本着它山之石可以攻玉的原则,对redis学习参考了《redis设计与实现》等一些网络上的资源,在此基础上阅读分析源码。在本笔记中,引用网络上资源非本人原创的地方都会加上标注说明,和原文链接。


简介:本节主要对redis进行介绍,然后是一个分析redis和memcache的性能测试。最后介绍一下redis的安装与使用。


OKay,开始干货吧。
Redis简介
Redis是什么

这个问题的结果影响了我们怎么用Redis。如果你认为Redis是一个key value store, 那可能会用它来代替MySQL;如果认为它是一个可以持久化的cache, 可能只是它保存一些频繁访问的临时数据。Redis是REmote DIctionary Server的缩写,在Redis在官方网站的的副标题是A persistent key-value database with built-in net interface written in ANSI-C for Posix systems,这个定义偏向key value store。还有一些看法则认为Redis是一个memory database,因为它的高性能都是基于内存操作的基础。另外一些人则认为Redis是一个data structure server,因为Redis支持复杂的数据特性,比如List, Set等。对Redis的作用的不同解读决定了你对Redis的使用方式。
互联网数据目前基本使用两种方式来存储,关系数据库或者key value。但是这些互联网业务本身并不属于这两种数据类型,比如用户在社会化平台中的关系,它是一个list,如果要用关系数据库存储就需要转换成一种多行记录的形式,这种形式存在很多冗余数据,每一行需要存储一些重复信息。如果用key value存储则修改和删除比较麻烦,需要将全部数据读出再写入。Redis在内存中设计了各种数据类型,让业务能够高速原子的访问这些数据结构,并且不需要关心持久存储的问题,从架构上解决了前面两种存储需要走一些弯路的问题。
以上简介摘自博文:http://timyang.net/data/redis-misunderstanding/


Redis与memcache的区别:

这里写图片描述

Memcache与redis的性能对比

Redis和Memcache,测试服务器是一个个人PC:配置一般(2CPU\2G内存),操作系统安装的CentOS。
redis memcache都是空的时候

redis设置100000个值开始时间:1311742106
redis设置100000个值开始时间:1311742123 耗时:16.8817
memcache设置100000个值开始时间:1311742123
memcache设置100000个值结束时间:1311742138 耗时:15.2574
redis和memcache有数据时

redis设置100000个值开始时间:1311742721
redis设置100000个值结束时间:1311742738 耗时:17.3401
memcache设置100000个值开始时间:1311742738
memcache设置100000个值结束时间:1311742753 耗时:15.6892

分别测试redis和memcache获取数据速度

redis数组获取100000个值开始时间:1311742144
redis数组获取100000个值结束时间:1311742398 耗时:253.9285
redis逐个获取100000个值开始时间:1311742398
redis逐个获取100000个值时间:1311742414 耗时:16.339
memcache数组获取100000个值开始时间:1311742414
memcache数组获取100000个值结束时间:1311742415 耗时:0.8022
memcache逐个获取100000个值开始时间:1311742415
memcache逐个获取100000个值结束时间:1311742428 耗时:13.38

综上分析

就以上测试结果,Redis和Memcache在写入性能上面差别不大,读取性能上面尤其是批量读取性能上面Memcache全面胜出,当然Redis也有自己的优点:比如数据持久化、支持更多的数据结构(Set List ZSet)等。
本小节摘自博文:http://www.cnblogs.com/jiunadianshi/articles/2422831.html


Redis的安装与使用

Redis的安装

本人阅读开源程序有一个习惯,一般会先把程序编译运行起来,操作一下软件。对软件的业务逻辑有一定的了解之后,再开始阅读源码。那么在这里首先说一下redis的安装与常用操作。网络上有很多关于redis的安装与使用的文章。
linux 系统上redis的安装与部署:
http://jingyan.baidu.com/article/e4511cf33577802b855eaf6d.html
mac os上redis的安装部署:
http://levi.cg.am/archives/2887
而redis的命令与使用这篇文章十分不错,推荐一下:
http://www.open-open.com/lib/view/open1409642154697.html
redis的使用

本着不重复造轮子的原则,redis的安装使用及常用命令推荐大家阅读这篇文章:
http://www.yiibai.com/redis/redis_environment.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值