Redis简介(01)历史与发展
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
Redis简介(01)历史与发展
Redis是⼀种基于键值对(key-value)的NoSQL数据库,与很多键值对数据库不同的是,Redis中的值可以是由string(字符串)、
hash(哈希)、list(列表)、set(集合)、zset(有序集合)、Bitmaps(位图)、HyperLogLog、GEO(地理信息定位)等多种数据结构和算法组成,因此Redis可以满⾜很多的应⽤场景,⽽且因为Redis会将所有数据都存放在内存中,所以它的读写性能⾮常惊⼈。
不仅如此,Redis还可以将内存的数据利⽤快照和⽇志的形式保存到硬盘上,这样在发⽣类似断电或者机器故障的时候,内存中的数据不会“丢失”。
除了上述功能以外,Redis还提供了键过期、发布订阅、事务、流⽔线、Lua脚本等附加功能。
总之,如果在合适的场景使⽤好Redis,它就会像⼀把瑞⼠军⼑⼀样所向披靡。
Redis借鉴了Linux操作系统对于版本号的命名规则:版本号第⼆位如果是奇数,则为⾮稳定版本(例如2.7、2.9、3.1),如果是偶数,则为稳定版本(例如2.6、2.8、3.0、3.2)。
当前奇数版本就是下⼀个稳定版本的开发版本,例如2.9版本是3.0版本的开发版本。
所以我们在⽣产环境通常选取偶数版本的Redis,如果对于某些新的特性想提前了解和使⽤,可以选择最新的奇数版本。
下⾯将对Redis发展过程中的⼀些重要版本及特性进⾏说明。
1.Redis
2.6
Redis2.6在2012年正式发布,经历了17个版本,到2.6.17版本,相⽐于Redis2.4,主要特性如下:
1)服务端⽀持Lua脚本。
2)去掉虚拟内存相关功能。
3)放开对客户端连接数的硬编码限制。
4)键的过期时间⽀持毫秒。
5)从节点提供只读功能。
6)两个新的位图命令:bitcount和bitop。
7)增强了redis-benchmark的功能:⽀持定制化的压测,CSV输出等功能。
8)基于浮点数⾃增命令:incrbyfloat和hincrbyfloat。
9)redis-cli可以使⽤--eval参数实现Lua脚本执⾏。
10)shutdown命令增强。
11)info可以按照section输出,并且添加了⼀些统计项。
12)重构了⼤量的核⼼代码,所有集群相关的代码都去掉了,cluster功能将会是3.0版本最⼤的亮点。
13)sort命令优化。
2.Redis2.8
Redis2.8在2013年11⽉22⽇正式发布,经历了24个版本,到2.8.24版本,相⽐于Redis2.6,主要特性如下:
1)添加部分主从复制的功能,在⼀定程度上降低了由于⽹络问题,造成频繁全量复制⽣成RDB对系统造成的压⼒。
2)尝试性地⽀持IPv6。
3)可以通过config set命令设置maxclients。
4)可以⽤bind命令绑定多个IP地址。
5)Redis设置了明显的进程名,⽅便使⽤ps命令查看系统进程。
6)config rewrite命令可以将config set持久化到Redis配置⽂件中。
7)发布订阅添加了pubsub命令。
8)Redis Sentinel第⼆版,相⽐于Redis2.6的Redis Sentinel,此版本已经变成⽣产可⽤。
3.Redis3.0
Redis3.0在2015年4⽉1⽇正式发布,相⽐于Redis2.8主要特性如下:
注意:Redis3.0最⼤的改动就是添加Redis的分布式实现Redis Cluster,填补了Redis官⽅没有分布式实现的空⽩。
Redis
Cluster经历了4年才正式发布也是有原因的,具体可以参考Redis Cluster的开发⽇志(/news/79)。
1)Redis Cluster:Redis的官⽅分布式实现。
2)全新的embedded string对象编码结果,优化⼩对象内存访问,在特定的⼯作负载下速度⼤幅提升。
3)lru算法⼤幅提升。
4)migrate连接缓存,⼤幅提升键迁移的速度。
5)migrate命令两个新的参数copy和replace。
6)新的client pause命令,在指定时间内停⽌处理客户端请求。
7)bitcount命令性能提升。
8)config set设置maxmemory时候可以设置不同的单位(之前只能是字
节),例如config set maxmemory1gb。
9)Redis⽇志⼩做调整:⽇志中会反应当前实例的⾓⾊(master或者slave)。
10)incr命令性能提升。
4.Redis3.2
Redis3.2在2016年5⽉6⽇正式发布,相⽐于Redis3.0主要特征如下:
1)添加GEO相关功能。
2)SDS在速度和节省空间上都做了优化。
3)⽀持⽤upstart或者systemd管理Redis进程。
4)新的List编码类型:quicklist。
5)从节点读取过期数据保证⼀致性。
6)添加了hstrlen命令。
7)增强了debug命令,⽀持了更多的参数。
8)Lua脚本功能增强。
9)添加了Lua Debugger。
10)config set⽀持更多的配置参数。
11)优化了Redis崩溃后的相关报告。
12)新的RDB格式,但是仍然兼容旧的RDB。
13)加速RDB的加载速度。
14)spop命令⽀持个数参数。
15)cluster nodes命令得到加速。
16)Jemalloc更新到4.0.3版本。
5.Redis4.0
可能出乎很多⼈的意料,Redis3.2之后的版本是4.0,⽽不是3.4、3.6、3.8。
⼀般这种重⼤版本号的升级也意味着软件或者⼯具本⾝发⽣了重⼤变⾰,下⾯列出Redis4.0的新特性:
1)提供了模块系统,⽅便第三⽅开发者拓展Redis的功能,更多模块详见:。
2)PSYNC2.0:优化了之前版本中,主从节点切换必然引起全量复制的问题。
3)提供了新的缓存剔除算法:LFU(Last Frequently Used),并对已有算法进⾏了优化。
4)提供了⾮阻塞del和flushall/flushdb功能,有效解决删除bigkey可能造成的Redis阻塞。
5)提供了RDB-AOF混合持久化格式,充分利⽤了AOF和RDB各⾃优势。
6)提供memory命令,实现对内存更为全⾯的监控统计。
7)提供了交互数据库功能,实现Redis内部数据库之间的数据置换。
8)Redis Cluster兼容NAT和Docker。