大数据学习之Redis、从零基础到入门(一)

news2024/9/28 17:32:18

目录

一、Redis入门概述

1. 是什么?

官方解释:

2. 能干嘛?

2.1 主流功能与应用

2.1.1分布式缓存

2.1.2内存存储和持久化(RDB+AOF)

2.1.3高可用架构搭建

2.1.4缓存穿透、击穿、雪崩

2.1.5分布式锁

2.1.6队列

2.2 总体功能概括

2.3 优势

3. 去哪下?

官网地址:

英文:

中文:

中文文档:

下载安装包:

其他文档资料:

Redis源码地址:

Redis在线测试:

Redis命令参考:

4. 怎么玩?

5.Redis迭代演化和Redis7新特性

5.1 版本迭代推演介绍

5.1.1 里程碑版本

5.1.2 命名规则

5.2 Redis7.0新特性概述

5.2.1 Redis Functions

5.2.2 Client-eviction

5.2.3 Multi-part AOF

5.2.4 ACL V2

5.2.5 新增命令

5.2.6 listpack替代ziplist

5.2.7 底层性能提升(和编码关系不大)

5.3 总结概括


Redis 全名:Remote Dictionary Server

一、Redis入门概述

1. 是什么?

官方解释:

Remote Dictionary Server(远程字典服务)是完全开源的,使用ANSIC语言编写遵守BSD协议,是一个高性能的Key-Value数据库提供了丰富的数据结构,例如String、Hash、List、Set、sortedset等等。数据是存在内存中的,同时Redis支持事务、持久化、LUA脚本、发布/订阅、缓存海汰、流技术等多种功能特性提供了主从模式、Redis Sentinel和Redis Cluster集群架构方案

Redis之父特雷兹

2. 能干嘛?

2.1 主流功能与应用

2.1.1分布式缓存

挡在MySQL数据库之前的带刀护卫

与传统的数据库关系(mysql)

Redis是key-value数据库(NOSQL一种),mysql是关系数据库

Redis数据操作主要在内存,而mysql主要存储在磁盘

Redis在某一些场景使用中要明显优于mysql,比如计数器、排行榜等方面

Redis通常用于一些特定场景,需要与Mysql一起配合使用

两者并不是相互替换和竟争关系,而是共用和配合使用

2.1.2内存存储和持久化(RDB+AOF)

redis支持异步将内存的数据写到硬盘上,同时不影响继续服务

虽然Redis是基于内存运行 的,但是也支持redis自身的数据持久化到硬盘里,因为如果Redis关闭或者宕机数据没有保存,下次查询的时候还得麻烦MySQL数据库,就比较消耗内存,写到硬盘里的东西还可以直接恢复到Redis,不麻烦MySQL

2.1.3高可用架构搭建

单机

主从

哨兵

集群:集群Redis的好处就是,当一台Redis挂掉之后,其他Redis可以顶上,不耽误Redis的工作

2.1.4缓存穿透、击穿、雪崩

如果只有一个Redis的话,当这一台Redis挂掉之后,client查询数据又变成直接向MySQL查询,这时候就容易造成缓存穿透、击穿、雪崩

2.1.5分布式锁

MySQL的是JVM,Redis需要跨服务器实现功能,需要加速,Redis也可以做到

2.1.6队列

Redis有各种各样的数据类型,比如string(字符串),hash(哈希),list(列表),set(集合)及zset(sorted set:有序集合)。

Reids提供list和set操作,这使得Redis能作为一个很好的消息队列平台来使用。

  • set是无序的,人们生活中使用的验证码也是无序的,当发送验证码的时候,用Redis快

我们常通过Reids的队列功能做购买限制。比如到节假日或者推广期间,进行一些活动,对用户购买行为进行限制,限制今天只能购买几次商品或者一段时间内只能购买一次。也比较适合适用。

在互联网应用中,有各种各样的排行榜,如电商网站的月度销量排行榜、社交APP的礼物排行榜、小程序的投票排行榜等等。Redis提供的zset数据类型能够快速实现这些复杂的排行榜。比如小说网站对小说进行排名,根据排名,将排名靠前的小说推荐给用户

2.2 总体功能概括

拥有十大数据类型,可以用作高可用,高性能的操作

支持持久化,Forking-->fork() 单独的备份

支持Redis Cluster 集群

哨兵:Redis 安装完毕后 直接是主从结构 ,主机挂掉之后,可以在从机里找一台上位变更

2.3 优势

性能极高 — Redis能读的速度是110000次/秒写的速度是81000次/秒

Redis数据类型丰富,不仅仅支持简单的key-value类型的数据同时还提供list,set,zset,hash等数据结构的存储

Redis支持数据的持久化,可以将内存中的数据保持在磁盘中,重启的时候可以再次加载进行使用

Redis支持数据的备份,即master-slave模式的数据备份

3. 去哪下?

官网地址:

英文:

https://redis.io/

中文:

(大佬翻译,是英文官方的映射,版本知识可能会落后一点)

http://www.redis.cn/

中文文档:

https://www.redis.com.cn/documentation.html

下载安装包:

https://redis.io/download/

其他文档资料:

Redis源码地址:

https://github.com/redis/redis

Redis在线测试:

https://try.redis.io/

Redis命令参考:

http://doc.redisfans.com

4. 怎么玩?

多种数据类型基本操作和配置

持久化和复制,RDB/AOF

事务的控制

复制,集群等

5.Redis迭代演化和Redis7新特性

5.1 版本迭代推演介绍

5.1.1 里程碑版本

5.1.2 命名规则

版本号第二位如果是奇数,则为非稳定版本 如2.7、2.9、3.1

版本号第二位如果是偶数,则为稳定版本 如2-6、2.8、3.0、3.2

5.2 Redis7.0新特性概述

5.2.1 Redis Functions

更高效更易用更好管理

5.2.2 Client-eviction

连接内存占用独立管理

5.2.3 Multi-part AOF

Redis的持久化:RDB 和 AOF

7.0之前AOF有且只有一个,7.0AOF变成了多个

AOFRW不再是运维痛点

5.2.4 ACL V2

精细化权限管理

5.2.5 新增命令

新增ZMPOPBZMPOP,LMPOP BLMPOP等新命令,对于EXPIRE和SET命令,新增了更多的命令参数选项。

例如,ZMPOP的格式如下: ZMPOP numkeys key [key ...]MIN|MAX[COUNT count],而BZMPOP是ZMPOP的阻塞版本。

5.2.6 listpack替代ziplist

跳表,压缩包等

7.0 没有了ziplist

5.2.7 底层性能提升(和编码关系不大)

5.3 总结概括

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1407850.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

JeecgBoot 3.6.1实现Modal对话框,以为审核数据为例

JeecgBoot 3.6.1实现Modal对话框 vue使用的是3.0版本 文章目录 JeecgBoot 3.6.1实现Modal对话框前言一、列表页面关键代码示例二、textAuditModal.vue代码示例三、test.api.ts总结 前言 在工作中,有一个需求,要求,在数据列表页,…

容联云入选中国大模型产业新锐企业TOP30

近日, WIM 2023(世界创新者年会)发布《2023中国大模型产业创新服务商TOP 30》名单,评选出30家2023年中国大模型领域做出卓越贡献的企业,凭借垂直行业大模型“赤兔大模型”展现出的创新力与商业落地速度,容联…

springboot项目中使用iframe引入页面

一、 <iframe name"uploadPage" src"/uploadImg.html" width"100%" height"50" marginheight"0" marginwidth"0" scrolling"no" frameborder"0"></iframe> 前提是将要引入的页面…

2012-2022年全国各省数字经济相关指标数据合集(18个指标)

2012-2022年全国各省数字经济相关指标数据合集&#xff08;18个指标&#xff09; 1、时间&#xff1a;2012-2022年 2、指标&#xff1a;地区、year、互联网接入端口数、互联网宽带接入用户数、互联网域名数、移动电话普及率、长途光缆线路长度&#xff08;万公里&#xff09;…

Linux 文件:IO接口详解及实操

一、C语言中的文件IO读写操作 在c语言文件中&#xff0c;创建、打开、读、写操作可以通过如下的代码进行&#xff1a; 1.1写文件 通过w指令对文件进行写入操作时&#xff0c;编译器会先将文件内容清空然后重新写入。 #include <stdio.h> #include <string.h> i…

山体滑坡监测预警系统-gnss位移监测站

GNSS山体滑坡位移监测站是一种利用全球导航卫星系统&#xff08;GNSS&#xff09;进行山体滑坡位移监测的设备。它通过接收和处理GNSS卫星信号&#xff0c;能够实时监测山体的位移变化&#xff0c;并将数据传输到后端系统进行分析和处理。 GNSS山体滑坡位移监测站具有高精度、…

基于springboot+vue的师生健康信息管理系统(前后端分离)

博主主页&#xff1a;猫头鹰源码 博主简介&#xff1a;Java领域优质创作者、CSDN博客专家、公司架构师、全网粉丝5万、专注Java技术领域和毕业设计项目实战 主要内容&#xff1a;毕业设计(Javaweb项目|小程序等)、简历模板、学习资料、面试题库、技术咨询 文末联系获取 研究背景…

java web mvc-03-JFinal

拓展阅读 Spring Web MVC-00-重学 mvc mvc-01-Model-View-Controller 概览 web mvc-03-JFinal web mvc-04-Apache Wicket web mvc-05-JSF JavaServer Faces web mvc-06-play framework intro web mvc-07-Vaadin web mvc-08-Grails JFinal JFinal 是基于 Java 语言的极…

CSC7225

CSC7225 为高性能电流模式 PWM 开关电源控制器&#xff0c;满足绿色环保标准&#xff1b;广泛适用于经济型开关电源&#xff0c;如 DVD、机顶盒、传真机、打印机、LCD 显示器等。CSC7225 采用 DIP-8 封装。 CSC7225主要特点  CSC7225内置 700V 高压功率开关管&#xff0c;外…

kubeadm 安装k8s集群后,master节点notready问题解决方案

使用kubeadm 安装k8s集群后&#xff0c;加载calico cni 网络组件后&#xff0c;master节点notready问题 表现为&#xff1a; 使用命令查看日志&#xff1a;journalctl -f -u kubelet 报错如下&#xff1a; Failed to start ContainerManager failed to initialize top level…

通过代理服务器的方式解决跨域问题

学习源码可以看我的个人前端学习笔记 (github.com):qdxzw/frontlearningNotes 觉得有帮助的同学&#xff0c;可以点心心支持一下哈 这里以本地访问https://heimahr.itheima.net/api/sys/permission接口为列子 Node.js 代理服务器 (server.js) 本次考虑使用JSONP或CORS代理来…

服务器配置优化句柄数量

当部署新的服务器环境时&#xff0c;需要对服务器的句柄数进行一次优化&#xff0c; 否则当用户量稍微增大可能会导致系统问题。 系统句柄数量 查看系统最大文件句柄数&#xff0c;执行命令&#xff1a;cat /proc/sys/fs/file-max&#xff0c;如果最大句柄数不能满足要求&am…

前端项目对接protobufjs的时候,踩坑总结

Protobuf&#xff08;Protocol Buffers&#xff09;是一种用于序列化结构化数据的语言无关、平台无关、可扩展的机制。在JS/TS项目中&#xff0c;使用WebSocket与Protobuf可以实现高效的通信和数据传输。protobufjs官方仓库:https://github.com/protobufjs/protobuf.js 安装pro…

列表的创建与删除

Python 中列表可以动态地添加、修改和删除元素&#xff0c;是 Python 编程中不可或缺的一部分。本文将介绍如何使用 Python 创建和删除列表&#xff0c;以及常用的方法和技巧。 创建列表 在 Python 中&#xff0c;我们可以使用一对方括号 [ ] 来创建一个空列表&#xff0c;也可…

瓦片地图编辑器——实现卡马克卷轴的编辑,键盘控制游戏移动和鼠标点击游戏编辑通过同一个视口实现。

左边是游戏地图编辑区&#xff0c;右边是地图缓冲区&#xff0c;解决了地图缓冲区拖动bug&#xff0c;成功使得缓冲区可以更新。 AWSD进行移动 鼠标左右键分别是绘制/拖动 按F1健导出为mapv3.txt F2清空数组 打印的是游戏数组 easyx开发devcpp 5.11 easyx20220922版本 #…

《GreenPlum系列》GreenPlum初级教程-GreenPlum详细入门教程

文章目录 GreenPlum详细入门教程第一章 GreenPlum介绍1.MPP架构介绍2.GreenPlum介绍3.GreenPlum数据库架构4.GreenPlum数据库优缺点 第二章 GreenPlum单节点安装1.Docker创建centos容器1.1 拉取centos7镜像1.2 创建容器1.3 进入容器1.4 容器和服务器免密操作1.4.1 生成密钥1.4.…

手动导入jar包到Maven的解决方案(简单有效!)

想要导入一个jar包到项目中&#xff0c;这个jar包在Maven中没有可以尝试以下方式。 第一步 先找到你maven的本地仓库&#xff0c;我的仓库就在这里&#xff0c;你可以根据你安装的maven找到你的目录 第二步 根据坐标创建文件夹。 这个依赖modbus4j.jar&#xff0c;Maven远…

TCP三握四挥(面试需要)

TCP建立连接需要三次握手过程&#xff0c;关闭连接需要四次挥手过程 三次握手 从图中可以看出&#xff0c;客户端在发起connect时&#xff0c;会发起第一次和第三次握手。服务端在接收客户端连接时&#xff0c;会发起第二次握手。 这三次握手&#xff0c;都会通过SYNACK的方式…

论文翻译:On Bringing Robots Home

On Bringing Robots Home 关于引入机器人到家庭 文章目录 On Bringing Robots Home关于引入机器人到家庭1 Introduction1 引言2 Technical Components and Method2 技术组件与方法2.1 Hardware Design2.1 硬件设计2.2 Pretraining Dataset – Homes of New York2.2 预训练数据…

AI研究必备!这些网站你不可不知

AI研究必备&#xff01;这些网站你不可不知 在人工智能的浪潮中&#xff0c;你是否感到手足无措&#xff1f;别担心&#xff0c;今天我就为大家揭晓那些AI研究者们的秘籍——他们常用的网站。这些网站不仅包含了丰富的资源&#xff0c;还能让你的研究之路更加顺畅。让我们一起…