redis的数据类型的操作增删改查

redis的数据类型的操作增删改查

redis的高可用:

在集群当中有一个非常重要的指标,提供正常服务的时间的百分比(365天)99.9%

redis的高可用的含义要更加宽泛,正常服务是指标之一数据容量扩展,数据的安全性

在redis中实现这种高可用技术:持久化 主从复制,哨兵模式 cluster集群。

持久化: 持久化是最简单的高可用方法,主要作用是数据备份,也就是把redis缓存在内存中的数据保存到本地的硬盘中

redis持久化的两种方式:

1、RDB持久化:redis在内存中的数据定时保存到磁盘。(自动执行,手动执行)

2、AOF持久化:redis的操作日志,以追加的方式写入一个AOF的文件,类似于mysql的binlog。

rdb的持久化: 指在指定的时间间隔内,将内存中当前进程中的数据生成快照保存到硬盘(快照持久化),用二进制压缩存储

保存的文件名的后缀.rdb redis启动时可以直接读取快照文件,实现数据恢复。

rdb的触发机制

手动机制:save bgsave都可以省程RDB文件。

save创建RDB文件时,整个redis进程会被阻塞,期间redis将无法进行读写操作,直到RDB文件创建完成为止。

bgsave就是主从复制的机制

bgsave的特点就是父进程会通过fork机制创建一个子进程,子进程的创建过程中,父进程会阻塞,子进程创建完毕,主进程会解除阻塞,然后由子进程来创建RDB文件。创建完成之后,通知主进程更新通知信息。

save 900 1

900秒 当时间到900秒时,如果redis的数据至少发生一次变化,就会执行bgsave,

save 300 10

300 秒 时间到300秒时,如果redis的数据至少发生10次变化,就会执行bgsave,

save 60 10000

60秒 时间到60秒时,如果redis的数据至少发生一万次变化,就会执行bgsave,

sava 120 1000 bgsave

save 60 10000 bgsave

数据变动越多,执行的时间要越短,数据变动不大,时间间隔要长一点。

rdbcompression yes

开启rdb的文件压缩功能,在高并发场景建议关闭。

除了配置文件中的save m n 之外

主从复制,从节点执行全量复制操作,主节点会执行bgsave,把rdb文件传送给从节点。

关闭主进程,shutdown只会,会自动执行rdb的持久化

启动时加载:

发现rdb文件被损坏,日志中会打印错误,redis会拒绝启动。

redis-check-rdb修复rdb的持久化文件。

AOF持久化:

aof持久化是将redis的每一次读 写 删除命令记录到一个单独的.aof结尾的文件。查询操作由主进程记录。当redis重启时,再次执行AOF文件中的命令来恢复数据。

AOF的实时性更好,也是主流的持久化方案。

aof-load-truncated yes

用于判断AOF文件,如果被截断时的行为

yes:发现在被截断(写入过程中出现了异常,导致文件未能完全写入) redis会尽可能恢复文件中的数据,redis会继续运行

no:发现AOF文件被截断,redis将拒绝启动。

数据完整性要求比较高用no

注重数据服务器的可用性用yes

rdb是redis的默认持久化文件,但是一但开启AOF持久化,那么redis会以AOF的持久化文件作为最高优先级。

AOF的重写功能

1、随着时间增长,AOF文件当中的数据也会不断增加,AOF的文件也会也来越大,过大的AOF文件不仅仅会影响,也会导致数据恢复的时间过长。

文件重写是指定期的重写AOF文件,减小AOF文件的体积。AOF重写是把redis进程内的数据,转化为写的命令,同步到新的aof文件当中(不会额外的生成一个新的文件,只是在原内容当中进行压缩)。不会对原有的AOF文件进行任何读写的操作。

*文件重写虽然是AOF持久化强烈推荐的,但不是必须的,没有重写并不影响redis启动时读写数据,在实际中,会关闭自动的文件重写,通过定时任务来完成。

AOF同步文件的策略的三种方式

appendfsync always

写入过程中,会立刻调用redis系统的fsync 操作立刻写入到AOF文件,这次写入都执行同步,硬盘的性能有瓶颈,硬盘的寿命也会大大降低

appendfsync everysec:命令写入,调用write操作,write操作结束后,线程会返回。FSYNC同步文件操作由专门的线程,每秒调用一次,这是一个这种的策略,是性能喝安全性的平衡,是redis的默认配置,也是推荐配置

appendfsync no :写入操作调用系统的write操作,不对AOF文件进行同步,操作系统来同步,同步周期30秒,文件同步的时间不可控,缓冲区会堆积大量数据,数据的安全也无法保证。

重写的出发条件是什么

1、手动触发

redis-cli bgrewriteaof

2、自动触发

auto-aof-rewrite-percentage 100

文件的大小超过基准的百分比,默认值就是100,文件的超过两倍时,执行bgrewriteaof,设置为0,禁用自动触发

100M 200M 200M 400M

auto-aof-rewrite-min-size 64mb

文件大于基准值,才会进行重写,整个值时AOF文件执行重写的最小值,避免开始穷redis后,文件太小,然后频繁的进行重写。

AOF为什么能够压缩文件;

1、重写的过程中,过期的数据不会写入文件

2、无效的命令不在写入文件,数据被重复设置,set test=1 set test 2 删除的数据也不会写入

多条命令合并成一个 sadd test1 v1 sadd test1 v2

sadd test1 v3 sadd test1 v1 v2 v3

重写之后AOF文件当中的命令减少了,空间也少了,恢复速度也增增加了 重写不是必须的

RDB和AOF之间的优缺点

RDB的优点:文件体积小,如果需要备份,网络传输速度很快,适合全量复制,恢复速度也比AOF要快

缺点:做不了实时的持久化,数据如此重要不能够容忍丢失的,另外RDB需要满足特定的格式,兼容性很差,老版本的RDB不支持新版本,(redis的版本一定要一致)5.0.7版本

AOF的优点;秒级的持久化。兼容性好,文本格式保存的命令。

缺点:文件大,恢复速度慢。AOF持久化需要频繁的向磁盘写入数据,磁盘的io压力也很大,对redis主进程的性能也会有一定影响。

重点:

持久化方式:redis的持久化也算是高可用的一种,通过备份文件来恢复数据,冷备份。

rdb :sava线上禁用,bgsave

AOF:实时持久化写入的是操作的命令,除了查 set del 会记录 get select不计入

实时记录恢复方式类似于mysql的binlog

重写;推荐但不是必须的,重写也是主进程创建一个子进程,在过程中产生的数据以及同步策略都会写入到AOF当中。

实验:重复写入数据

重复插入同一个数据只会写入最后一个设置的数据

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

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

一起学docker系列之八使用 Docker 安装配置 MySQL

目录 前言步骤 1:拉取 MySQL 镜像步骤 2:运行 MySQL 容器步骤 3:检查容器状态步骤 4:进入 MySQL 容器步骤 5:配置 MySQL 字符编码步骤 6:重启 MySQL 容器步骤 7:测试字符编码步骤 8:…

如何使用Python在3dMax控制网格对象?

我们以一个在3dMax中使用Python脚本在网格对象对象上创建水波变形作为例子。 首先,在3dmax创建两个对象,一个“box”对象,将长宽方向的分段设置的多一些(目的是为了后面的水波变形),一个“点”帮助对象&am…

王者农药小游戏

游戏运行如下: sxt Background package sxt;import java.awt.*; //背景类 public class Background extends GameObject{public Background(GameFrame gameFrame) {super(gameFrame);}Image bg Toolkit.getDefaultToolkit().getImage("C:\\Users\\24465\\D…

辅助驾驶功能开发-系统方案篇-地平线超级驾驶解决方案介绍

01.产品方案 Horizon Matrix SuperDrive超级驾驶解决方案,助力汽车智能化步入人机共驾时代 SuperDrive超级驾驶解决方案,全面整合了自动驾驶、智能交互、云端大脑三大模块,形成完整的泛车载AI人工智能系统,帮助整车智能化提升到一个新的高度。该方案的核心硬件-车载中央计…

链表?细!详细知识点总结!

链表 定义:链表是一种递归的数据结构,它或者为空(null),或者是指向一个结点(node)的引用,该结点含有一个泛型的元素和一个指向另一条链表的引用。 ​ 其实链表就是有序的列表,它在内…

YOLOv8改进 | 2023 | FocusedLinearAttention实现有效涨点

论文地址:官方论文地址 代码地址:官方代码地址 一、本文介绍 本文给大家带来的改进机制是Focused Linear Attention(聚焦线性注意力)是一种用于视觉Transformer模型的注意力机制(但是其也可以用在我们的YOLO系列当中从而提高检测…

虹科Pico汽车示波器 | 汽车免拆检修 | 2011款瑞麒M1车发动机起动困难、加速无力

一、故障现象 一辆2011款瑞麒M1车,搭载SQR317F发动机,累计行驶里程约为10.4万km。该车因发动机起动困难、抖动、动力不足、热机易熄火等故障进厂维修。用故障检测仪检测,发动机控制单元(ECU)中存储有故障代码“P0340相…

不同视频格式如何一键生成二维码?二维码视频制作在线技巧

现在通过扫码看视频是很多人在使用的一种方式,通过制作视频二维码来引导用户了解自己的内容,但是视频有很多种不同的格式,那么有什么方法能够将不同格式的视频生成二维码呢?下面来教大家一招,通过在线的视频二维码生成…

Windows Server 2012R2 修复CVE-2016-2183(SSL/TLS)漏洞的办法

一、漏洞说明 Windows server 2012R2远程桌面服务SSL加密默认是开启的,且有默认的CA证书。由于SSL/ TLS自身存在漏洞缺陷,当开启远程桌面服务,使用漏洞扫描工具扫描,发现存在SSL/TSL漏洞。远程主机支持的SSL加密算法提供了中等强度的加密算法,目前,使用密钥长度大于等于5…

2.Linux系统及常用命令

目录 一、Linux文件系统和目录 1.1 Linux文件系统 1.2Linux主要目录 二、Linux远程连接 2.1前置条件 2.2 具体远程操作 三、Linux的常用命令 3.1 Linux命令的格式 3.2 Linux命令的帮助信息查看 3.3 Linux文件操作常用命令 命令中快捷键 以管理员权限执行命令 3.3.1…

重生之我是一名程序员 41 ——字符串函数(2)

哈喽啊大家晚上好!今天呢我们延续昨天的内容,给大家带来第二个字符串函数——strcat函数。 首先呢,还是先带大家认识一下它。strcat函数是C语言中用于将两个字符串连接起来的函数,其函数原型为: char *strcat(char *…

Ubuntu 安装 JMeter:轻松上手

Apache JMeter 是一个开源的负载测试工具,可以用于测试静态和动态资源,确定服务器的性能和稳定性。在本文中,我们将讨论如何下载和安装 JMeter。 安装 Java(已安装 Java 的此步骤可跳过) 要下载 Java,请遵…