Redis: A persistent key-value database with built-in net interface written in ANSI-C for Posix systems. Redis是现在很火的高性能KV内存数据库,支持丰富的数据类型,支持持久化、数据同步等DB特性。Redis是开源的,代码量不大2W+,代码风格和实现都很值得学习。在开源的时代,模仿好代码估计是最快的学习方式。

使用

推荐如下资料:

Redis系统性介绍

一个很棒的Redis介绍PPT

Redis官方文档

【redis学习总结】【http://blog.csdn.net/wudongxu/article/details/7005830

实现

推荐如下资料:

Redis内存存储结构分析

Redis RDB文件格式全解析,英文:https://github.com/sripathikrishnan/redis-rdb-tools/wiki/Redis-RDB-Dump-File-Format

协议规范(Protocol specification)

Redis: under the hood

解密Redis持久化

Replication

Redis官方文档

可复用代码(版本2.6.3)

malloc封装():tcmalloc|jemalloc|libc 使用最佳的malloc封装,libc的malloc不提供获取分配内存大小的接口。

zmalloc.h, zmalloc.c

异步网络库:封装各种事件组件,提供统一的接口。

ae.c  ae_epoll.c  ae_evport.c  ae.h  ae_kqueue.c  ae_select.c

TCP|UNIX网络封装: 很简单的封装。

anet.h, anet.c, syncio.c(阻塞式读写)

数据结构

adlist.h, adlist.c (通用双向链表), ziplist.h, ziplist.c, zipmap.h, zipmap.c,  intset.h, intset.c(基于连续内存的小数据存储结构), sds.h, sds.c(Binary Safe字符串)

lzf压缩算法

lzf -- an extremely fast/free compression/decompression-method: http://liblzf.plan9.de/

lzf_c.c  lzf_d.c  lzf.h  lzfP.h

文件读写: 封装基于文件和内存的数据读写。

rio.h, rio.c

工具

crc64.c,  endianconv.h, endianconv.c(将大端数据转成小端,性能考虑), memtest.c(内存测试工具), pqsort.h, pqsort.c(部分快排), rand.h, rand.c, sha1.c, sha1.h(开源的sha), util.c, util.h(字符串匹配,字符串和整形数转换)

设计

灵活协议

Redis采用可读可组合的文本协议。Redis采用统一的命令格式,基于统一的规范命令Redis天生具备解析和执行多条命令的能力,因此Redis非常容易支持:批量命令、事务、原子操作(脚本原子操作)等。

权衡

Redis的设计需要做各种权衡,每一种权衡都意味着不同的实现方案、资源、性能的折中。Redis不可能适合所有的使用场景,作为KV的内存数据库,Redis做了很多针对性设计:高性能优先、高内存使用效率、多样的数据结构(内存易实现)、单线程读写(CPU非瓶颈)、数据快照(RDB文件)、可过期的数据,同时提供其他可配置的功能:AOF(日志)、可配置的小数据格式、主从Replication、严格内存限制或swap、LRU缓存、磁盘存储等。

小技巧

Redis Administration

FAQ

memory-optimization

其他资料

Redis资料汇总专题

最新文章

  1. PHP的一些开源项目网站
  2. 关于BigDecimal 的计算
  3. 新公司入职第一天遇到的 关于 CSS 单行溢出文本显示省略号...的问题
  4. unity 播放过场动画
  5. Docker大行其道—镜像
  6. BZOJ3550: [ONTAK2010]Vacation
  7. Integer.valueOf与Integer.parseInt的小疑惑
  8. ANDROID_SDK_HOME设置
  9. extjs 优化小建议
  10. Windows Server2012上使用Nginx做文件服务器
  11. Spring事件解析
  12. 解决springboot jar包冲突
  13. 生产与学术之Pytorch模型导出为安卓Apk尝试记录
  14. Java 内部类及其原理
  15. 【算法】LeetCode算法题-Search Insert Position
  16. aspx页面,取得Excel某列不同类型的数据为空
  17. awt
  18. sql 身份证计算年龄和性别
  19. Kotlin 条件控制
  20. Tomcat通过Redis实现session共享的完整部署记录

热门文章

  1. LibSvm添加到Matlab
  2. Android系统移植与调试之------->如何修改Android设备状态条上音量加减键在横竖屏切换的时候的显示于隐藏
  3. JavaScript四则运算计算器
  4. nodejs开发解决方案
  5. random模块(随机数库)
  6. [转]linux shell 流程控制(条件if,循环【for,while】,选择【case】语句实例
  7. hadoop linux 杂记
  8. centos6 没有eth0网络
  9. centos中安装php7
  10. layer满屏/禁止最大化最小化 可以做选择框使用