redis是什么
Redis:REmote Dictionary Server(远程字典服务器)。
官网解释
Remote Dictionary Server(远程字典服务)是完全开源的,使用ANSIC语言编写遵守BSD协议,是一个高性能的Key-Value数据库提供了丰富的数据结构,例如String、Hash、List、Set、SortedSet等等。数据是存在内存中的,同时Redis支持事务、持久化、LUA脚本、发布/订阅、缓存淘汰、流技术等多种功能特性提供了主从模式、Redis Sentinel和Redis Cluster集群架构方案。
Redis之父安特雷兹
redis可以做什么
主流功能与应用
- 分布式缓存,挡在mysql数据库之前的护卫
- 内存存储和持久化(RDB+AOF),redis支持异步将内存中的数据写到硬盘上,同时不影响继续服务
- 高可用架构搭配
- 缓存穿透、击穿、雪崩
- 分布式锁
- 队列
- 排行版+点赞
- 。。。。。。
一图,总体功能概述
优势
- 性能极高 – Redis能读的速度是110000次/秒,写的速度是81000次/秒
- Redis数据类型丰富,不仅仅支持简单的key-value类型的数据,同时还提供list、set、zset、hash等数据结构的存储
- Redis支持数据的持久化,可以将内存中的数据保持在磁盘中,重启的时候可以再次加载进行使用
- Redis支持数据的备份,即master-slave模式的数据备份
小总结
redis下载
官网地址
英文
中文
下载安装包
本次下载Redis7 ==》redis-7.0.0.tar.gz
Redis6
其他文档资料
Redis源码地址(中国大陆打开慢 多刷几次或梯子试试)
redis怎么使用
- 官网
- 多种数据类型基本操作和配置
- 持久化和复制,RDB/AOF
- 事务的控制
- 复制,集群等
- ......
Redis迭代演化和Redis7新特性浅谈
时间推移,版本升级
Redis版本迭代推演介绍
- 几个里程碑式的重要
- 命名规则
Redis7.0新特性概述
Releases · redis/redis · GitHub
新特性
部分新特性总览
- Redis Functions
- Client-eviction
- Multi-part AOF
- ACL V2
- 新增命令
- listpack替代ziplist
- 底层性能提升(和编码关系不大)
- 。。。。。。
总体概述:
大体和之前的redis版本保持一致和稳定,主要是自身底层性能和资源利用率上的优化和提高,如果你生产上系统稳定,不用着急升级到最新的redis7版本,当然,O(∩_∩)O哈哈~,如果你是从零开始的新系统,直接上Redis7.0-GA版。^_^
多AOF文件支持
|
7.0 版本中一个比较大的变化就是 aof 文件由一个变成了多个,主要分为两种类型:基本文件(base files)、增量文件(incr files),请注意这些文件名称是复数形式说明每一类文件不仅仅只有一个。在此之外还引入了一个清单文件(manifest) 用于跟踪文件以及文件的创建和应用顺序(恢复)
|
config命令增强
|
对于Config Set 和Get命令,支持在一次调用过程中传递多个配置参数。例如,现在我们可以在执行一次Config Set命令中更改多个参数: config set maxmemory 10000001 maxmemory-clients 50% port 6399
|
限制客户端内存使用
Client-eviction
| 一旦 Redis 连接较多,再加上每个连接的内存占用都比较大的时候, Redis总连接内存占用可能会达到maxmemory的上限,可以增加允许限制所有客户端的总内存使用量配置项,redis.config 中对应的配置项
// 两种配置形式:指定内存大小、基于 maxmemory 的百分比。
maxmemory-clients 1g
maxmemory-clients 10%
|
listpack紧凑列表调整
|
listpack 是用来替代 ziplist 的新数据结构,在 7.0 版本已经没有 ziplist 的配置了(6.0版本仅部分数据类型作为过渡阶段在使用)listpack 已经替换了 ziplist 类似 hash-max-ziplist-entries 的配置
|
访问安全性增强ACLV2
|
在redis.conf配置文件中,protected-mode默认为yes,只有当你希望你的客户端在没有授权的情况下可以连接到Redis server的时候可以将protected-mode设置为no
|
Redis Functions
| Redis函数,一种新的通过服务端脚本扩展Redis的方式,函数与数据本身一起存储。
简言之,redis自己要去抢夺Lua脚本的饭碗
|
RDB保存时间调整
|
将持久化文件RDB的保存规则发生了改变,尤其是时间记录频度变化
|
命令新增和变动
| Zset (有序集合)增加 ZMPOP、BZMPOP、ZINTERCARD 等命令
Set (集合)增加 SINTERCARD 命令
LIST (列表)增加 LMPOP、BLMPOP ,从提供的键名列表中的第一个非空列表键中弹出一个或多个元素。
|
性能资源利用率、安全、等改进
| 自身底层部分优化改动,Redis核心在许多方面进行了重构和改进
主动碎片整理V2:增强版主动碎片整理,配合Jemalloc版本更新,更快更智能,延时更低
HyperLogLog改进:在Redis5.0中,HyperLogLog算法得到改进,优化了计数统计时的内存使用效率,7更加优秀
更好的内存统计报告
如果不为了API向后兼容,我们将不再使用slave一词......
|