网站中所有标签,wordpress怎么降级,phpstudy做正式网站,wordpress调用ja✅作者简介#xff1a;大家好#xff0c;我是Leo#xff0c;热爱Java后端开发者#xff0c;一个想要与大家共同进步的男人#x1f609;#x1f609; #x1f34e;个人主页#xff1a;Leo的博客 #x1f49e;当前专栏#xff1a; Java从入门到精通 ✨特色专栏#xf…
✅作者简介大家好我是Leo热爱Java后端开发者一个想要与大家共同进步的男人 个人主页Leo的博客 当前专栏 Java从入门到精通 ✨特色专栏 Redis7从实战到高级 本文内容Redis7入门概述 ️个人小站 个人博客欢迎大家访问 个人知识库Leo知识库欢迎大家访问
1. Redis是什么
Remote Dictionary Server(远程字典服务)是完全开源的使用ANSIC语言编写遵守BSD协议是一个高性能的Key-Value数据库提供了丰富的数据结构例如String、Hash、List、Set、SortedSet等等。数据是存在内存中的同时Redis支持事务、持久化、LUA脚本、发布/订阅、缓存淘汰、流技术等多种功能特性提供了主从模式、Redis Sentinel和Redis Cluster集群架构方案。 作者 安特雷兹
个人Github https://github.com/antirez
个人博客 https://antirez.com/latest/0
1.1 主流功能与应用
1.分布式缓存挡在MySQL数据库之前的带刀护卫 与传统数据库关系
Redis是key-value数据库(NoSQL一种)MySQL是关系型数据库。Redis数据操作主要在内存而MySQL主要存储在磁盘。Redis在某一些场景使用中要明显优于MySQL比如计数器、排行榜等方面。Redis通常用于一些特定场景需要与MySQL一起配合使用。两者并不是相互替换和竞争的关系而是共用和配合使用
2.内存存储和持久化RDB和AOF
Redis支持异步将内存中的数据写到硬盘上同时不影响继续服务
3.高可用架构搭配
单机、主从、哨兵、集群
4.缓存穿透、击穿、雪崩
5.分布式锁
6.队列
Redis提供list和Set操作这使得Redis能作为一个很好的消息队列平台来使用。
我们常通过Redis的队列功能做购买限制。比如到了节假日或者推广期间进行一些活动对用户购买行为进行限制限制今天只能购买几次商品或者一段时间内只能购买一次。也比较适合使用。
7.排行榜点赞
在互联网应用中有各种各样的排行榜如电商网站的月度销量排行榜、社交APP的礼物排行榜、小程序的投票排行榜等等。Redis提供的zset数据类型能够快速实现这些复杂的排行榜。
比如小说网站对小说进行排名根据排名将排名靠前的小说推荐给用户。
1.2 总体功能概述 1.3 优势
性能极高-Redis读的速度是110000次/秒写的速度是81000次/秒
Redis数据类型丰富不仅仅支持简单的Key-Value类型的数据同时还提供listsetzsethash等数据结构的存储
Redis支持数据的持久化可以将内存中的数据保持在磁盘中重启的时候可以再次加载进行使用
Redis支持数据的备份即master-slave模式的数据备份
1.4 小总结 2.Redis能干嘛
官网地址 :
英文官网 Redis
中文官网 Redis网站
安装包https://redis.io/download/选择redis7.0版本即可 Redis源码地址https://github.com/redis/redis
Redis在线测试地址(不用下载也能玩)https://try.redis.io/
Redis命令参考http://doc.redisfans.com/
3. Redis怎么使用
官网文档多种数据类型基本操作和配置持久化和复制RDB/AOF事务的控制复制集群等
3.1 Redis迭代演化 5.0版本是直接升级到6.0版本对于这个激进的升级Redis之父antirez表现得很有信心和兴奋所以第一时间发文来阐述6.0的一些重大功能Redis 6.0.0 GA is out!:随后 R e d i s 再接再厉直接王炸 R e d i s 7.0 − − − 2023 年爆款 \textcolor{red}{随后Redis再接再厉直接王炸Redis7.0---2023年爆款} 随后Redis再接再厉直接王炸Redis7.0−−−2023年爆款
2022年4月27日Redis正式发布了7.0更新
(其实早在2022年1月31日Redis已经预发布了7.0rc-1近过社区的考验后确认没有重大Bug才会正式发布)3.2 Redis版本迭代推演介绍
几个里程碑式的重要版本:如上图redis历史版本回顾
命名规则Redis从发布至今已经有十余年的时光了一直遵循着自己的命名规则:
版本号第二位如果是奇数则为非稳定版本如2.7、2.9、3.1版本号第二位如果是偶数则为稳定版如2.6、2.8、3.2当前奇数版本就是下一个稳定版本的开发版如2.9版本就是3.0版本的开发版本我们可以通过redis.io官网来下载自己感兴趣的版本进行源码阅读历史发布版本的源码https://download.redis.io/releases/
Redis7.0新特性概述
https://github.com/redis/redis/releases可以查询到历史发布版本根据7.0-rc1预发布版本我们可以看到Redis7的新特性 3.3 部分新特性总览
2022年4月正式发布的Redis7.0是目前Redis历史版本中变化最大的版本。首先它有超过50个以上的新增命令其次它有大量核心特性的新增和改进。 1. Redis Functions 2. Client-eviction 3. Multi-part AOF 4. ACL v2 权限控制 5. 新增命令
新增ZMPOPBZMPOPLMPOPBLMPOP等新命令对于EXPIRE和SET命令新增了更多的命令参数选项。例如ZMPOP的格式如下ZMPOP numkeys key [key ...] MIN|MAX [COUNT count],而BZMPOP是ZMPOP的阻塞版本。6. listpack替代ziplist
listpack是用来替代ziplist的新数据结构在7.0版本已经没有ziplist的配置了6.0版本仅部分数据类型作为过渡阶段在使用7. 底层性能提升(和编码关系不大) 3.4 Redis7部分新特性说明
总体概述
大体和之前的redis版本保持一致和稳定主要是自身底层性能和资源利用率上的优化和提高如果生产上系统稳定不用着急升级到最新redis7版本如果从零开始新系统直接上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-client 1gmaxmemory-client 10%listpack紧凑列表调整listpack 是用来替代 ziplist 的新数据结构在 7.0 版本已经没有 ziplist 的配置了 (6.0版本仅部分数据类型作为过渡阶段在使用listpack已经替换了ziplist类似hash-max-ziplist-entries 的配置访问安全性增强ACLV2在redis.conf配置文件中protected-mode默认为yes只有当你希望你的客户端在没有授权的情况下可以连接到Redis server的时候可以将protect-mode设置为noredis functionRedis函数一种新的通过服务端脚本扩展Redis的方式函数与数据本身一起存储。简言之redis自己要去抢夺Lua脚本的饭碗RDB保存时间调整将持久化文件RDB的保存规则发生了改变尤其是时间记录频度变化命令新增和变动Zset (有序集合)增加 ZMPOP、BZMPOP、ZINTERCARD 等命令Set (集合)增加 SINTERCARD 命令LIST(列表)增加 LMPOP、BLMPOP 从提供的键名列表中的第一个非空列表键中弹出一个或多个元素。性能资源利用率、安全等改进自身底层部分优化改动Redis核心在许多方面进行了重构和改进主动碎片整理V2:增强版主动碎片整理配合Jemalloc版本更新更快更智能延时更低HyperLogLog改进:在Redis5.0中HyperLogLog算法得到改进优化了计数统计时的内存使用效率7更加优秀更好的内存统计报告如果不是为了API向后兼容我们将不再使用slave一词…政治正确