目前我们部门存储平台使用的redis版本是2.4.8,版本已比较久远,很多新功能都没办法提供。近期有打算同步redis社区最新版本,所以前期先做了个redis各版本新功能调研,现把调研汇总结果展示如下:
redis版本 |
功能点 |
2.6 |
Lua脚本支持 |
2.6 |
新增PEXIRE、PTTL、PSETEX过期设置命令,key过期时间可以设置为毫秒级 |
2.6 |
新增位操作命令:BITCOUNT、BITOP |
2.6
扫描二维码关注公众号,回复:
11619886 查看本文章
|
新增命令:dump、restore,即序列化与反序列化操作 |
2.6 |
新增命令:INCRBYFLOAT、HINCRBYFLOAT,用于对值进行浮点数的加减操作 |
2.6 |
新增命令:MIGRATE,用于将key原子性地从当前实例传送到目标实例的指定数据库上 |
2.6 |
放开了对客户端的连接数限制 |
2.6 |
hash函数种子随机化,有效防止碰撞 |
2.6 |
SHUTDOWN命令添加SAVE和NOSAVE两个参数,分别用于指定SHUTDOWN时用不用执行写RDB的操作 |
2.6 |
虚拟内存Virtual Memory相关代码全部去掉 |
2.6 |
sort命令会拒绝无法转换成数字的数据模型元素进行排序 |
2.6 |
不同客户端输出缓冲区分级,比如普通客户端、slave机器、pubsub客户端,可以分别控制对它们的输出缓冲区大小 |
2.6 |
更多的增量过期(减少阻塞)的过期key收集算法 ,当非常多的key在同一时间失效的时候,意味着redis可以提高响应的速度 |
2.6 |
底层数据结构优化,提高存储大数据时的性能 |
2.8 |
引入PSYNC,主从可以增量同步,这样当主从链接短时间中断恢复后,无需做完整的RDB完全同步 |
2.8 |
从显式ping主,主可以扫描到可能超时的从 |
2.8 |
新增命令:SCAN、SSCAN、HSCAN和ZSCAN |
2.8 |
crash的时候自动内存检查 |
2.8 |
新增键空间通知功能,客户端可以通过订阅/发布机制,接收改动了redis指定数据集的事件 |
2.8 |
可绑定多个IP地址 |
2.8 |
可通过CONFIGSET设置客户端最大连接数 |
2.8 |
新增CONFIGREWRITE命令,可以直接把CONFIGSET的配置修改到redis.conf里 |
2.8 |
新增pubsub命令,可查看pub/sub相关状态 |
2.8 |
支持引用字符串,如set 'foo bar' "hello world\n" |
2.8 |
新增redis master-slave集群高可用解决方案(Redis-Sentinel) |
2.8 |
当使用SLAVEOF命令时日志会记录下新的主机 |
3.0 |
实现了分布式的Redis即Redis Cluster,从而做到了对集群的支持 |
3.0 |
全新的"embedded string"对象编码方式,从而实现了更少的缓存丢失和性能的提升 |
3.0 |
大幅优化LRU近似算法的性能 |
3.0 |
新增CLIENT PAUSE命令,可以在指定时间内停止处理客户端请求 |
3.0 |
新增WAIT命令,可以阻塞当前客户端,直到所有以前的写命令都成功传输并和指定的slaves确认 |
3.0 |
AOF重写过程中的"last write"操作降低了AOF child -> parent数据传输的延迟 |
3.0 |
实现了对MIGRATE连接缓存的支持,从而大幅提升key迁移的性能 |
3.0 |
为MIGRATE命令新增参数:copy和replace,copy不移除源实例上的key,replace替换目标实例上已存在的key |
3.0 |
提高了BITCOUNT、INCR操作的性能 |
3.0 |
调整Redis日志格式 |
3.2 |
新增对GEO(地理位置)功能的支持 |
3.2 |
新增Lua脚本远程debug功能 |
3.2 |
SDS相关的优化,提高redis性能 |
3.2 |
修改Jemalloc相关代码,提高redis内存使用效率 |
3.2 |
提高了主从redis之间关于过期key的一致性 |
3.2 |
支持利用upstart和systemd管理redis进程 |
3.2 |
将list底层数据结构类型修改为quicklist,在内存占用和RDB文件大小方面有极大的提升 |
3.2 |
SPOP命令新增count参数,可控制随机删除元素的个数 |
3.2 |
支持为RDB文件增加辅助字段,比如创建日期,版本号等,新版本可以兼容老版本RDB文件,反之不行 |
3.2 |
通过调整哈希表大小的操作码RDB_OPCODE_RESIZEDB,redis可以更快得读RDB文件 |
3.2 |
新增HSTRLEN命令,返回hash数据类型的value长度 |
3.2 |
提供了一个基于流水线的MIGRATE命令,极大提升了命令执行速度 |
3.2 |
redis-trib.rb中实现将slot进行负载均衡的功能 |
3.2 |
改进了从机迁移的功能 |
3.2 |
改进redis sentine高可用方案,使之可以更方便地监控多个redis主从集群 |
4.0 |
加入模块系统,用户可以自己编写代码来扩展和实现redis本身不具备的功能,它与redis内核完全分离,互不干扰 |
4.0 |
优化了PSYNC主从复制策略,使之效率更高 |
4.0 |
为DEL、FLUSHDB、FLUSHALL命令提供非阻塞选项,可以将这些删除操作放在单独线程中执行,从而尽可能地避免服务器阻塞 |
4.0 |
新增SWAPDB命令,可以将同一redis实例指定的两个数据库互换 |
4.0 |
新增RDB-AOF持久化格式,开启后,AOF重写产生的文件将同时包含RDB格式的内容和AOF格式的内容,其中 RDB格式的内容用于记录已有的数据,而AOF格式的内存则用于记录最近发生了变化的数据 |
4.0 |
新增MEMORY内存命令,可以用于查看某个key的内存使用、查看整体内存使用细节、申请释放内存、深入查看内存分配器内部状态等功能 |
4.0 |
兼容NAT和Docker |