Redis探索之旅

目录

今日良言:有志者自有千计万计,无志者只感千难万难

一、简介

二、Redis的安装

三、Redis的简单使用

四、Redis相关知识点

1.缓存分类

2.五大基本数据类型使用

3.持久化

4.常见面试题


今日良言:有志者自有千计万计,无志者只感千难万难

一、简介

先来介绍一下什么是缓存

缓存是一个高速数据交换的存储器,使用它可以快速的访问和操作数据。

对于程序来说,如果没有使用缓存,程序的调用流程如下:

但是,随着公司的业务发展,逐步变成了多个程序调用一个数据库的情况了:

当公司业务发展到一定规模之后,最可能出现性能拼劲的地方就是数据库了,为了防止数据库被过渡的浪费,就引入了缓存,避免程序直接访问数据库,,加入缓存后,流程如下:

加入缓存以后,所有的程序不会直接调⽤数据库,而是会先调用缓存,当缓存中有数据时会直接返回,当缓存中没有数据时才去查询数据库,这样就大大的降低了数据库的压力,并加速了程序的响应速度。

 缓存优点:

1. 缓存一般都是使用key-value 查询数据的,因为不像数据库还有查询的条件等因素,所以查询的性能一般会比数据库高。

2. 缓存的数据是存储在内存的,而数据库的数据是存储在磁盘中的,因为内存的操作性能远远大于磁盘,因此缓存的查询效率会高很多;

3.缓存更容易做分布式部署,而数据库很难实现分布式部署,因此缓存的负载和性能更适合平行扩展和增加。

Redis 是常见的分布式缓存。

二、Redis的安装

1. yum 命令安装 redis

 使用以下命令,直接将 redis 安装到 linux 服务器:

yum -y install redis  

 2. 启动 redis

使用以下,以后台运行方式启动 redis

redis-server /etc/redis.conf &

这里的redis.conf 是redis的配置文件,可以在这个配置文件中修改 redis的相关配置

3. 操作redis

使用以下命令启动 redis 客户端:

redis-cli  

如果修改了 redis 的默认端口号6379,启动 redis 客户端使用如下命令:

redis-cli -p xxxx

-p后面是修改后的端口号

4. 设置远程连接

1)将 redis 配置文件下载到本地:redis 配置文件是 linux 下的 /etc/redis.conf

先切到 etc 目录下,然后找redis.conf 文件

 

2)将 redis.conf 配置文件中的 “bind 127.0.0.1” 注释。

打开 redis.conf 文件,然后找到 bind 127.0.0.1 并注释

 3)将 redis.conf 中的“protected-mode yes” 改为“protected-mode no”

4.将修改后的 redis.conf 文件上传到 etc目录下

5.使用 命令 redis-cli shutdown 先关闭服务, 再使用 redis-server /etc/redis.conf 启动 redis 服务

 注:

远程连接后,redis 的默认端口容易被入侵,云服务器也会被入侵,这就导致会有人使用你的服务器攻击别人,如下图:(博主被搞了好久,天天攻击别人)

 所以,为了安全起见,可以修改一下 redis 的端口,还是下载 redis.conf 文件,然后修改里面配置,找到 port,修改默认端口 6379 为别的端口:

修改了端口号以后,需要在云服务器的防火墙那里开放这个端口。 

 然后再新增一个密码:

找到   requirepass foobared  然后注释掉,再新增:

requirepass 你的密码

 然后再重复 上述 4)  5) 步。

此时,使用 redis-cli -p 端口号 打开客户端:

 此时还需要输入密码:

auth 后面跟上刚才新增的密码

出现 OK 后,即可使用本地redis 

 

 可以使用如下软件远程连接 redis:

 

打开后:

 

 然后即可连接成功。

三、Redis的简单使用

四、Redis相关知识点

1.缓存分类

缓存大致可以分类两类:

本地缓存

本地缓存也叫单机缓存,也就是说可以应用在单机环境下的缓存。所谓的单机环境是指,将服务部署到⼀台服务器上,如下图:

本地缓存的特征是只适用于当前系统。
常见本地缓存有:Spring Cache、MyBatis 的缓存等。

分布式缓存

分布式缓存是指可以应⽤在分布式系统中的缓存。所谓的分布式系统是指将⼀套服务器部署到多台服务器,并且通过负载分发将⽤户的请求按照⼀定的规则分发到不同服务器,如下图:

 常见的分布式缓存有: Redis 和 Memcached。

Redis 和 Memcached 的区别如下:

1. 存储方式不同:memchched 把数据全部存到内存之中,断电后会挂掉,数据不能超过内存大小。redis 有部分存到硬盘中,这样能保持数据的持久性。

2. 数据支持类型: memcached 对数据类型支持相对简单,redis 有复杂的数据类型。

3. 存储值大小不同:redis 最大可以达到 512mb,memcached 只有 1mb。

通常情况下,如果是单机 Spring 项⽬,会直接使⽤ Spring Cache 作为本地缓存,如果是分布式环境⼀般会使⽤ Redis。

2.五大基本数据类型使用

Redis 有五大基本数据类型:

String     字符串类型

Hash      字典类型

List         列表类型

Set         集合类型

ZSet       有序集合类型

其中最常用的是 字符串类型和 字典类型。

String     字符串类型

字符串类型,它是以键值对 key-value 的形式进行存储的,根据 key 值获取 value 值,它的使用相对比较简单,但是实际项目中应用非常广泛。
字符串的使用如下:

 

Hash      字典类型

字典类型又被称为散列表或者是哈希表类型,它是将一个键值 key 和一个特殊的“哈希表”关联起来,这个“哈希表”包含两列数据:字段和值,它就相当于 Java 中的 Map<String,Map<String,String>> 结构,同时,这里的字典类型又很像 Java 中的会话。

字典类型的使用如下:

通常情况下,字典类型会使用数组的方式来存储相关的数据,但发生哈希冲突时才会用链表的结构来存储数据。

List         列表类型

列表类型是一个使用链表结构存储的有序结构,它的元素插入会按照先后顺序存储到链表结构中,因此它的元素操作(插入和删除),时间复杂度为O(1),所以相对而言它的速度还是比较快的,但是它的查询操作的时间复杂度为 O(n),因此查询可能会比较慢。

列表类型的使用如下:

 列表的典型使用场景有两个:

1)消息队列

2)文章列表

Set         集合类型

集合类型 是一个无序并唯一的键值集合。

集合类型的使用如下:

集合类型和列表类型的区别如下:

1)列表可以存储重复元素,集合只能存储非重复元素。

2)列表是按照先后顺序存储元素的,而集合是无序方式存储元素的。

ZSet       有序集合类型

有序集合类型(Sorted Set)相比于集合类型多了一个排序属性 score(分值),对于有序集合 ZSet 来说,每个存储元素相当于有两个值组成的,一个是有序集合的元素值,一个是排序值。有序集合的存储元素值是不能重复的,但分值是可以重复的。

有序集合类型的使用如下:

有序集合的使用场景如下:

1)学生成绩排名。

2)粉丝列表,根据关注的先后时间排序。 

3.持久化

所谓的持久化,就是将数据从内存保存到磁盘的过程,它的目的就是为了防止数据丢失。

redis 的持久化方式有三种:

1)快照方式(RDB,Redis DataBase)

将某一时刻的内存数据,以二进制的方式写入磁盘。

RDB 的优点:

a)RDB 的内容为二进制的数据,占用内存更少,更紧凑,更适合做备份文件。

b)RDB 对容灾恢复非常有用,它是一个紧凑的文件,可以更快的传输到远程服务器进行 Redis 服务恢复。

c)与AOF 的格式相比,RDB 文件可以更快的重启。

RDB 的缺点:

a)因为 RDB 只能保存某个时间间隔的数据,如果中途 Redis 服务被以外终止了,则会丢失一段时间的 Redis 数据。

b)RDB 需要经常 fork() 才能使用子进程将其持久化到磁盘上,如果数据集很大,fork() 可能很耗时,并且,如果数据集很大且 CPU 性能不佳,则会导致 Redis 停止为客户端服务几毫秒甚至一秒钟。

2)文件追加方式(AOF,Append Only File) 

记录所有的操作命令,并以文本的形式追加到文件中。

AOF 的优点:

a)AOF 持久化保存的数据更加完整,AOF 提供了三种保存策略:每次操作保存、每秒钟保存一次、跟随系统的持久化策略保存,其中每秒保存一次,从数据的安全性和性能两方面考略是一个不错的选择,也是 AOF 默认的策略,即使发生了意外情况,最多只会丢失 1 s的数据。

b)AOF 采用的是子命令追加的写入方式,所以不会出现文件损坏的问题,即使由于某些以外原因,导致了最后操作的持久化数据写⼊了⼀半,也可以通过 redis-check-aof 工具轻松的修复。

c)AOF 持久化文件,非常容易理解和解析,它是把所有的 Redis 键值操作命令,以文件的方式存入了磁盘,即使不小心使用 fullshall 命令删除了所有键值信息,只要 AOF 文件,删除最后的 fullshall 命令,重启 Redis 即可恢复之前误删的数据。

AOF 的缺点:

a)对于相同的数据集来说,AOF 文件要大于 RDB 文件。

b)在 Redis 负载比较高的情况下,RDB 比 AOF 性能更好。

c)RDB 使用快照的形式来持久化整个 Redis 数据,而 AOF 只是将每次执行的命令追加到 AOF 文件中,因此,RDB 比 AOF 文件更健壮。

3)混合持久化方式

Redis 4.0 之后新增的方式,混合持久化是结合了 RDB 和 AOF 的优点,在写入的时候,先把当前的数据 以 RBD 的形式写入文件的开头,再将后续的操作命令以 AOF 的形式存入文件,这样既能保证 Redis 重启时的速度,又能降低数据丢失的风险。

混合持久化的优点:

结合了 RDB 和 AOF 的优点,开头为 RDB 的格式,使得 Redis 可以更快的启动,同时结合了 AOF 的优点,降低了大量数据丢失的风险。

混合持久化的缺点:

a)AOF 文件中添加了 RDB 格式的内容,使得 AOF 文件的可读性变得很差。

b)兼容性差,如果开启混合持久化,那么此混合持久化 AOF 文件,就不能用在 Redis 4.0 之前的版本。

4.常见面试题

接下来,介绍一下Redis 的相关面试题:

1)缓存雪崩

缓存雪崩指的是在短时间内,大量缓存同时过期,导致大量的用户请求直接操作数据库,从而对数据库造成了很大的压力,严重情况下可能会导致数据库宕机,这种情况称为缓存雪崩。

缓存雪崩的解决方案:

a)加锁排队

加锁排队可以起到缓冲的作用,方式大量的用户请求同时操作数据库,但它的缺点是增加了系统的响应时间,降低了系统的并发量,牺牲了一部分用户的体验。

b)随机化过期时间

为了避免缓存同时过期,在设置缓存的时候,添加随机过期时间,这样就可以极大的避免大量缓存同时失效。        

c)设置二级缓存

二级缓存指的是:除了 Redis 本身的缓存之外,再设置一层缓存,当 Redis 失效之后,先去查询二级缓存,并非直接查询数据库。

2)缓存穿透

缓存穿透指的是:查询缓存和数据库无结果,由于数据库查询无结果,出于容错考虑,不会将结果保存到缓存中,因此每次请求都会去查询数据,这种情况就叫做缓存穿透。

缓存穿透的解决方案:

缓存空结果

每次将数据库查询的数据都保存到缓存中,为了提高前台用户的使用体验(解决长时间内查询不到任何信息的情况),可以将空结果的缓存时间设置的短一些,例如:3-5分钟。

3)缓存击穿

缓存击穿指的是:某一热点缓存,在某一时刻过期,此时大量用户请求直接操作数据库,会给数据库造成巨大的压力,这种情况就叫做缓存击穿。

缓存击穿的解决方案:

a)加锁排队

和解决缓存雪崩的加锁排队的方法类似,都是在查询数据库的时候加锁排队,避免大量用户同时请求数据库,以此来减少数据库的压力。

b)设置永不过期

对于热点缓存,可以设置永不过期,这样就能包含保证数据的稳定性。但是需要注意,每次数据库的数据更改以后,需要更新热点缓存的数据,不然就会造成查询结果的误差。

4)缓存预热

缓存预热并不是一种问题,而是使用缓存时的一个优化方案,它可以提高前台用户的使用体验。

缓存预热指的是:在系统启动的时候,先把查询结果预存到缓存中,以便用户后面查询时可以直接从缓存中读取,节约用户的等待时间。

缓存预热的实现思路有三种:

a)把需要缓存的方法写到系统初始化方法中,这样系统在启动的时候就会自动的加载数据并缓存数据。

b)把需要缓存的方法挂载到某个页面或者后端接口上,手动触发缓存预热。

c)设置定时任务,定时自动进行缓存预热。

补充:

最后介绍一下 Redis 集群

随着业务的不断发展,单机 Redis 的性能已经不能满足需求了,此时需要将单机 Redis 扩展为多机服务,Redis 多机服务 主要包含以下3个内容:

1)Redis 主从同步

2)Redis 哨兵模式

3)Redis 集群服务(Redis 3.0新增功能)

 1)主从同步

主从同步(主从复制)是 Redis 高可用服务的基石,也是多机运行中最基础的一个。把主要存储数据的节点叫做主节点(master),把其它通过复制主节点数据的副本节点叫做从节点(从节点),如下图:

在Redis 中一个主节点可以拥有多个从节点,一个从节点也可以是其它服务器的主节点,如下图:

 

主从同步优点:

a)性能方面

有了主从同步之后,可以把查询任务分配给从服务器,用主服务器来执行写操作,这样极大的提高了程序运行的效率,把所有压力分摊给各个服务器。

b)高可用

当有了主从同步之后,当主服务器节点发生宕机之后,可以迅速的把从节点提升为主节点,为 Redis 服务器的宕机恢复节省了宝贵时间。

c)防止数据丢失

当主服务器的磁盘坏掉之后,其他从服务器还保留着相关的数据,不至于数据全部丢失。

主从同步的缺点:

当主节点崩溃之后,需要人工干预才能恢复 Redis 的正常使用。

 

2)Redis 哨兵模式

当主从服务器发生宕机的节点比较多的情况下,如果需要人工恢复,这样的难度和花费时间是很大的,因此,需要一个自动的工具——Redis Sentinel(哨兵模式)来把手动的过程变成自动的,让 Redis 拥有自动容灾恢复的能力。

使用哨兵模式可以用来监控主从服务器节点,并在主从服务器出现问题的时候,自动容灾恢复。

哨兵模式如下图:

 

3)Redis 集群服务(Redis 3.0新增功能)

Redis 集群(Redis Cluder)是 Redis 多机运行最完美的解决方案,它是 Redis 3.0之后推出的服务,它的出现可以让我们完全抛弃主从同步和哨兵模式来实现 Redis 多机运行。

Redis 集群 是无代理模式去中心化的运行模式,客户端发送的绝大多数命令会直接交给相关节点执行,这样大部分请求命令无需转发或者仅转发一次的情况下就能完成请求和响应,所以集群单个节点的性能与单机  Redis 服务器的性能是非常接近的,因此在理论情况下,当水平扩展一倍的主节点就相当于请求处理的性能也提高了一倍,所以 Redis 集群的性能是非常高的。

Redis 集群如下图:

Redis 集群可以有无数个主从节点,而 Redis 的主从同步只能有一个主节点,因此,Redis 集群拥有更强大的平行扩展能力,也就是说,当 Redis 集群拥有两个主节点时,从理论上来说,Redis 的性能比单机服务来说性能提高了 2 倍。


以上就是 Redis 的相关内容。      

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

音视频 FFmpeg命令行搭建

文章目录 一、配置二、测试 一、配置 以FFmpeg4.2.1 win32为例 解压ffmpeg-4.2.1-win32-shared.zip 拷⻉可执⾏⽂件到C:\Windows拷⻉动态链接库到C:\Windows\SysWOW64 注&#xff1a;WoW64 (Windows On Windows64)是⼀个Windows操作系统的⼦系统&#xff0c;被设计⽤来处理许…

【机器学习1】什么是机器学习机器学习的重要性

什么是机器学习? 简而言之&#xff0c;机器学习就是训练机器去学习。 机器学习作为人工智能(Artificial Intelligence,AI)的一个分支&#xff0c;以其最基本的形式来使用算法通过从数据中获取知识来进行预测。 不同于人类通过分析大量数据手动推导规则和模型&#xff0c;机…

24届近5年上海交通大学自动化考研院校分析

今天给大家带来的是上海交通大学控制考研分析 满满干货&#xff5e;还不快快点赞收藏 一、上海交通大学 学校简介 上海交通大学是我国历史最悠久、享誉海内外的高等学府之一&#xff0c;是教育部直属并与上海市共建的全国重点大学。经过120多年的不懈努力&#xff0c;上海交…

Jenkins集成appium自动化测试(Windows篇)

一&#xff0c;引入问题 自动化测试脚本绝大部分用于回归测试&#xff0c;这就需要制定执行策略&#xff0c;如每天、代码更新后、项目上线前定时执行&#xff0c;才能达到最好的效果&#xff0c;这时就需要进行Jenkins集成。 不像web UI自动化测试可以使用无痕浏览器做到无界…

Vc - Qt - QPainter translate

QPainter的translate()函数是用来对绘制坐标系统进行平移操作的方法。它可以将绘制的原点&#xff08;坐标轴的起始点&#xff09;在水平和垂直方向上进行平移。以下是一个使用QPainter的translate()方法进行坐标平移的示例代码&#xff1a; QPainter painter(this);// 绘制一个…

Python爬虫的Selenium(学习于b站尚硅谷)

目录 一、Selenium  1.为什么要学习Selenium  &#xff08;1&#xff09;什么是Selenium  &#xff08;2&#xff09;为什么使用selenium?  &#xff08;3&#xff09;代码演示 2. selenium的基本使用  &#xff08;1&#xff09;如何安装selenium  &#xff08;2…

有哪些pdf修改方法?这几种方法学会就够了

有哪些pdf修改方法&#xff1f;PDF是一种非常常见的电子文档格式&#xff0c;它有很多优点&#xff0c;例如可读性强、易于保护、易于打印等等。但是&#xff0c;有时候我们需要对PDF进行修改&#xff0c;例如添加、删除或修改文本、更改图片、合并或分割文件等等。那么今天就给…

mysql_docker主从复制_实战_binlog混合模式_天座著

步骤1&#xff1a;拉取镜像 docker pull mariadb:latest 步骤2.1&#xff1a;创建两个文件夹用于放置挂载mysql的my.cnf /tianzuomysqlconf/master /tianzuomysqlconf/slave mkdir /tianzuomysqlconf cd /tianzuomysqlconf mkdir master mkdir slave 步骤2.2&#xff1a;创…

Python 开发工具 Pycharm —— 使用技巧Lv.2

pydoc是python自带的一个文档生成工具&#xff0c;使用pydoc可以很方便的查看类和方法结构 本文主要介绍&#xff1a;1.查看文档的方法、2.html文档说明、3.注释方法、 一、查看文档的方法 **方法1&#xff1a;**启动本地服务&#xff0c;在web上查看文档 命令【python3 -m…

剑指Offer12.矩阵中的路径 C++

1、题目描述 给定一个 m x n 二维字符网格 board 和一个字符串单词 word 。如果 word 存在于网格中&#xff0c;返回 true &#xff1b;否则&#xff0c;返回 false 。单词必须按照字母顺序&#xff0c;通过相邻的单元格内的字母构成&#xff0c;其中“相邻”单元格是那些水平…

关于Express 5

目录 1、概述 2、Express 5的变化 2.1 弃用或删除内容的列表&#xff1a; app.param&#xff08;name&#xff0c;fn&#xff09;名称中的前导冒号&#xff08;&#xff1a;&#xff09; app.del() app.param&#xff08;fn&#xff09; 复数方法名 res.json&#xff0…

Python批量查字典和爬取双语例句

最近&#xff0c;有网友反映&#xff0c;我的批量查字典工具换到其它的网站就不好用了。对此&#xff0c;我想说的是&#xff0c;互联网包罗万象&#xff0c;网站的各种设置也有所不同&#xff0c;并不是所有的在线字典都可以用Python爬取的。事实上&#xff0c;很多网站为了防…

计算机是怎么存储和识别人类高级语言的

目录 1、计算机是怎么“存储”人类的高级语言的&#xff1f;2、 UTF-8和UTF-32的区别3、UTF-8是如何区分字节的长度呢&#xff1f;&#xff08;即如何识别这一串二进制是多少个字节的&#xff1f;&#xff09;4、计算机是如何识别人类的高级语言的&#xff1f; 1、计算机是怎么…

八、复用(1)

本章概要 组合语法继承语法 初始化基类带参数的构造函数 委托 代码复用是面向对象编程&#xff08;OOP&#xff09;最具魅力的原因之一。 对于像 C 语言等面向过程语言来说&#xff0c;“复用”通常指的就是“复制代码”。任何语言都可通过简单复制来达到代码复用的目的&#…

使用JProfiler进入JVM分析

要评测JVM&#xff0c;必须将JProfiler的评测代理加载到JVM中。这可以通过两种不同的方式发生&#xff1a;在启动脚本中指定-agentpath VM参数&#xff0c;或者使用attach API将代理加载到已经运行的JVM中。 JProfiler支持这两种模式。添加VM参数是评测的首选方式&#xff0c;集…

【MMU】认识 MMU 及内存映射的流程

MMU&#xff08;Memory Manager Unit&#xff09;&#xff0c;是内存管理单元&#xff0c;负责将虚拟地址转换成物理地址。除此之外&#xff0c;MMU 实现了内存保护&#xff0c;进程无法直接访问物理内存&#xff0c;防止内存数据被随意篡改。 目录 一、内存管理体系结构 1、…

openssl安装问题合辑

1.openssl拖累nginx编译失败 问题描述&#xff1a; 因为漏洞原因&#xff0c;升级openssl之后需要重新编译nginx&#xff0c;进行了以下步骤&#xff1a; config没问题&#xff0c;但是make一直报错 初步判断是openssl安装有问题&#xff0c;原因不明&#xff0c;重装了opens…

Java后台生成ECharts图片

前言 通过echarts的jar包&#xff0c;Java后台生成一张图片&#xff0c;并把图片插入到word中。关于word插图片的代码在下一章。 需要用到的工具PhantomJS,Echarts-convert.js,jquery.js,echarts.js。 1.PhantomJS 介绍 PhantomJS是一个不需要浏览器的富客户端。 官方介绍&…

第八章:Linux信号

系列文章目录 文章目录 系列文章目录前言linux中的信号进程对信号的处理信号的释义 信号的捕捉信号的捕捉signal()信号的捕捉sigaction() 信号的产生通过终端按键产生信号前台进程与后台进程 kill()用户调用kill向操作系统发送信号raise()进程自己给自己发任意信号&#xff08;…

利用Google Docs的评论功能投递钓鱼链接

情报背景 利用Google drive等可信云服务进行的网络钓鱼攻击活动日益增长&#xff0c;这种攻击手段利用了高可信度的云服务骗取受害者的信任&#xff0c;并且可以绕过基于域名的安全策略。 近期Avanan公司发现了一种新的邮件钓鱼方式&#xff0c;攻击者利用Google docs的评论功…