Redis5.0新特性
stream--一种新的数据类型
之前redis共有7中数据类型:
字符串(string),哈希(hash),列表(list),集合(set),有序集合(sorted set)
位图 ( Bitmaps ),基数统计 ( HyperLogLogs )
现在又加了一种stream
Redis stream本质上是个时序数据结构
支持多播的可持久化的消息队列,用于实现发布订阅功能
集群管理功能集成到redis-cli
在Redis4.x及之前版本,需要安装redis-trib模块管理集群,因为绝大部分集群功能需要依赖redis-trib模块实现。
Redis 5.x及以上版本彻底抛弃了ruby,将集群管理功能集成到了redis-cli工具中。
配置文件redis.conf
-
salve名词全部替换为replica
因为政治正确的原因,slave这个词不能用了,所有redis.conf中全部替换为replica
所以,主从配置由以前的slaveof <masterip> <masterport>
改为 replicaof <masterip> <masterport>
还有很多主从配置的命令也同样修改了
-
从5.0开始,备节点默认将忽略maxmemory这个参数
过期数据的淘汰只会发生在主节点,然后同步del命令给备节点进行删除
-
aof-use-rdb-preamble默认为打开了
这个功能就是当aof文件进行重写时,用rdb格式保存当前的数据,新的数据用aof追加
以前这个配置默认时关闭的,现在改为打开了
-
动态hz参数dynamic-hz
hz参数用于指定Redis后台任务的执行频率,这些任务包括关闭超时的客户端连接、主动清除过期key等。
5.0之前的redis版本,hz参数一旦设定之后就是固定的了。
hz默认是10。这也是官方建议的配置。
如果改大,表示在reids空闲时会用更多的cpu去执行这些任务。官方并不建议这样做。
但是,如果连接数特别多,在这种情况下应该给与更多的cpu时间执行后台任务。
所以有了这个dynamic-hz参数,默认就是打开。当连接数很多时,自动加倍hz,以便处理更多的连接。
-
增加了一个rdb持久化时优化
rdb-save-incremental-fsync默认就是true
rdb文件每增加32mb 就执行fsync一次(增量式,避免一次性大写入导致的延时)
这个是针对rdb模式的优化,aof模式在4版本的时候已经有这个优化了aof-rewrite-incremental-fsync
-
增加了绑核配置 可以将不同的redis的线程和进程绑定到特定的cpu上,以便最大化利用服务器的性能。 这项能力在将redis的不同线程绑定到不同cpu时很有用,更有用的场景是在一台server上 启动多个redis实例,可以将不同的redis绑定到指定的cpu上。 语法和taskset命令(linux的绑核命令)一样
-
能够在arm上启动redis了 在arm64架构下启动redis会报ARM64-COW-BUG警告,redis不能启动。可以开启这个忽略 ignore-warnings ARM64-COW-BUG
网友评论