Redis(超详细)

Redis


Redis概念:

Redis是开源的,遵循BSD的,基于内存数据存储,被用于作为数据库、缓存机制、消息中间件;


Redis的特点:

1.高性能key/valu内存xing数据库;

2.支持丰富的数据类型

3.支持持久化;

4.单线程,单进程。


Redis为什么快?

他直接运行在内存上,他查询速率要比硬盘快上很多倍,他是单线程。 

NoSQL(Not only SQL)

概念

意即不仅仅是SQL,泛指非关系型数据库;


NoSQL的四大分类:


1.键值key-value存储数据库;
2.列存储数据库;
3.文档型数据库;
4.图形数据库。


redis-cli:是redis提供的命令行客户端;

redis-server:是redis的服务端启动脚本;

redis-sentinel:是redis的哨兵启动脚本。


五种基本数据类型:


1.String 存字符串 验证码


String:通常用于存储验证码 set get 多个值 mset mget

设置有效时间:expire key time / setex key time value

查看存活时间 ttl key

追加 sppend key value 数值加减 -1 decr +1 incr + by key

2.List 排序 商品列表

list:有序的可重复的集合;通常用于商品列表的展示,

lpush lrange key 起始索引 结束索引

删除重复元素:lrem key 删除个数 value

获取列表个数 llen key

3.Ste 共同好友,可能认识的人

set:无序的不可重复的集合;通常用于好友推荐,共同好友。

sadd 获取所有元素 smembers key 获取集合元素个数 scard key

求差集 sdiff 求交集 sinter

4.Zset 有序不可重复  排行榜

zset:可排序,不可重复的set集合;通常用于排行榜。

zadd 返回个数 zcard 升序 zrange 降序 zrevrange

5.Hash 

hash:key{key value}

hset hget hgetall

判断key是否存在:hexists 获得所有的key hkeys 获得所有的值 hvals

Redis的持久化

1.RDB(快照)

01.BGSAVE

第一种是客户端通过BGSAVE命令来创建一个快照,当接收到客户端的BGSAVE命令时,redis会调用fork来创建一个子进程,然后子进程负责将快照写入磁盘中,而父进程则继续处理命令请求。

02.SAVE

第二种是客户端通过SAVE命令来创建快照,接收到SAVE命令的redis服务器在快照创建完毕之前将不再响应任何其他的命令。这个命令不常用,因为使用SAVE命令在创建快照完毕之前,redis处于阻塞状态,无法对外服务。

2.AOF(只追加日志文件)

AOF可以将所有客户端的所有写命令记录在日志文件中。

特点:

这种方式可以将所有客户端执行的写命令记录到日志文件中,AOF持久化会将被执行的写命令写到AOF的文件末尾,以此来记录数据发生的变化,因此只要redis从头到尾执行一次AOF文件所包含的所有写命令,就可以恢复AOF文件的记录的数据集.

日志追加频率

1.everysec每秒执行一次同步显示的将多个命令同步到磁盘(推荐);

2.always每个redis写命令都要同步写入磁盘,严重降低redis速度(谨慎使用);

3.no 由操作系统决定何时同步(不推荐)。

AOF重写

AOF重写是我们创建一个新的AOF文件,把对里边儿的所有的数据进行一个命令重写的方式,写到这个新的AOF文件里面,并需把旧的AOF文件替换掉。

Redis主从复制

Redis是一种常见的数据备份方式,可以解决冗余备份,实现读写分离等功能;Redis的原理其实就是一个redis实例的数据复制到多个redis实例上,一个redis为主节点,多个redis实例为从节点,主节点负责所有数据的写操作,然后将写操作同步给从节点,从节点只接收读请求,不处理任何的写请求,从而保证了数据的一致性。

Redis哨兵机制

哨兵机制是redis高可用性的重要保障,哨兵机制是由哨兵节点组成,这些哨兵节点会定期检查Redis实例的健康状态,并在主节点出现故障时,哨兵机制就会自动在从节点中选举新的主节点,同时,哨兵节点还可以操作故障转移操作,将原本的从节点提升为新的主节点,并重新建立主从关系。如果旧主节点恢复了,就会成为新主节点的从节点。

缓存雪崩:

redis中多个key同时失效,过期的数据在redis中就会消失,这个时候如果多个请求来访问,redis就无法响应,就会去访问数据库,数据库就瞬间感觉到压力大而卡死或者宕机;

雪崩解决方案:

1.给key设置随机的失效时间;

 2.集群方案放置宕机不可用。

击穿:

redis中某一个key失效,这个时候有很多请求来访问这个失效的key,在redis中得不到响应,就去访问数据库,导致数据库瘫痪;

击穿解决方案:

1.互斥锁

 2.逻辑过期

穿透:

用户发送请求的数据在redis中和数据库中都不存在,这样缓存永远都不会失效,请求最终都到了数据库上。

解决方案:

1.当在数据库查询的结果也不存在的时候,可以返回null值给redis,并给null设置失效时间;

2.布隆过滤器。

延迟双删

为了保证在修改或者删除的时候,redis中的数据和数据库中的数据保持一致;当用户进行修改或者删除的操作时,先将redis中的缓存删除,然后去数据库去做对应操作,这个时候有用户进来读取这条信息,那么这条数据就会重新加载redis缓存中,所以当数据库操作完成后,需要再一次删除redis中的缓存,从而保证redsi中的数据和数据库中的数据保持一致。

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

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

相关文章

CRMEB 多店商品详情页装修说明

一、功能介绍 商家可调整商品详情各板块样式,可根据不同的需求开启或关闭单独的板块 二、操作流程 装修 > 商品详情 三、功能说明 1、商品信息 可控制商品详情页面商品信息的显示与隐藏 2、会员信息,排行榜 控制商品详情页面会员信息及排行榜的…

idea中的git在clone文件提示 filename too long

一 解决版本 1.1 问题描述以及解决办法 当在Windows系统下使用Git时出现“filename too long”错误: git config --system core.longpaths true

rsa加签验签C#和js、java、微信小程序互通

js实现rsa加签验签 https://github.com/kjur/jsrsasign 11.1.0版本 解压选择需要的版本&#xff0c;这里选择all版本了 <!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><title>JS RSA加签验签</title&g…

Unity的渲染管线

渲染管线 概念 Unity的渲染管线是在图形学渲染管线的基础上&#xff0c;加上了高度可配置可扩展的框架&#xff0c;允许开发者自定义渲染流程。 渲染管线&#xff08;渲染流水线&#xff09;概述&#xff1a;将数据分阶段的变为屏幕图像的过程。 数据指的是模型、光源和摄像…

Java——访问修饰符

一、访问修饰符是什么 Java中的访问修饰符用于控制类、接口、构造函数、方法和数据成员&#xff08;字段&#xff09;的可见性和访问级别。 Java提供了四种访问修饰符&#xff1a; 访问修饰符同一类内同一包内不同包的子类不同包的非子类适用对象public可见可见可见可见类、…

卫士通电科网安安全IpSec网关Ukey开发对接

官方公开的开发文档&#xff0c;有几个坑&#xff0c;着重说一下踩坑的记录过程。 1、通过官方的客户端接口模拟程序获取前端参数&#xff1a;随机数和token 2、java程序调用官方sdk&#xff0c;postman请求测试&#xff1a; 3、贴出关键的java集成类&#xff1a; import cn.h…

国产AI之光!KIMI大模型详细使用入门指南(非常详细)零基础入门到精通,收藏这一篇就够了

在目前的AI大模型领域&#xff0c;OpenAI公司开发的Chat-GPT毫无疑问是领头羊&#xff0c;但其使用有着众所周知的限制条件。 提到国产AI大模型&#xff0c;热度最高的毫无疑问就是月之暗面公司训练的KIMI大模型&#xff0c;堪称国产AI之光&#xff0c;也是我本人高频使用的两…

Matplotlib绘制一个X轴2个Y轴的图表

import matplotlib matplotlib.use(Agg) # 使用Agg后端&#xff0c;这个后端适用于生成图像文件但不显示它们 import matplotlib.pyplot as plt fig plt.figure(figsize(15, 8))# 字体使用楷体 matplotlib.rc("font", family"Microsoft YaHei") ax1 fig…

Nginx 负载均衡实现上游服务健康检查

Nginx 负载均衡实现上游服务健康检查 Author&#xff1a;Arsen Date&#xff1a;2024/06/20 目录 Nginx 负载均衡实现上游服务健康检查 前言一、Nginx 部署并新增模块二、健康检查配置2.1 准备 nodeJS 应用程序2.2 Nginx 配置负载均衡健康检查 小结 前言 如果你使用云负载均衡…

七连发吴谨言专访揭秘

七连发&#xff01;吴谨言专访揭秘&#xff0c;薛芳菲魅力再升级在娱乐圈的繁星中&#xff0c;总有那么一些独特的光芒&#xff0c;她们用才华和魅力照亮前行的道路。近日&#xff0c;备受瞩目的“六公主”平台连续发布了七条关于吴谨言的专访&#xff0c;引发了广大网友的热烈…

常微分方程算法之编程示例一(欧拉法)

目录 一、研究问题 二、C代码 三、计算结果 一、研究问题 前面几节内容介绍了常微分方程有限差分格式的推导。为加强对本专栏知识的理解&#xff0c;从本节开始&#xff0c;我们补充一些具体算例及相应的编程。 欧拉法的原理及推导请参考&#xff1a; 常微分方程算法之欧拉…

NXP i.MX8系列平台开发讲解 - 3.15 Linux 之USB子系统(一)

专栏文章目录传送门&#xff1a;返回专栏目录 Hi, 我是你们的老朋友&#xff0c;主要专注于嵌入式软件开发&#xff0c;有兴趣不要忘记点击关注【码思途远】 目录 Linux 之USB子系统(一) 1. USB基础简介 1.1 USB的传输模式 1.2 USB 的设备描述符 1.3 USB 类的定义分类 2…

不在枯燥用第三方库简化你的编程之路

简介&#xff1a; Python作为一种多用途的编程语言,得益于其丰富的第三方库和框架,极大地拓展了其功能和应用领域.这些工具不仅提升了开发效率,也使得Python在各个领域展现出色的表现. 今天我们就来聊一聊Python 第三方库是由第三方开发者编写并共享的库,可用于扩展 Python 的…

深度剖析现阶段的多模态大模型做不了医疗

导读 在人工智能的这波浪潮中&#xff0c;以ChatGPT为首的大语言模型&#xff08;LLM&#xff09;不仅在自然语言处理&#xff08;NLP&#xff09;领域掀起了一场技术革命&#xff0c;更是在计算机视觉&#xff08;CV&#xff09;乃至多模态领域展现出了令人瞩目的潜力。 这些…

X86+FPGA, NXP+FPGA:工控稳“固”之选 赋能CPCI/VPX智能轨交新变革

工业IPC在目前大时代背景下面临机遇,但挑战同样也不少。在轨道交通领域&#xff0c;工控机必须具备高可靠性和稳定性&#xff0c;能够在复杂且严苛的工作环境中长时间无故障运行&#xff1b;需要满足严格的实时性和响应性能要求&#xff0c;确保能够迅速准确地处理传感器信号和…

【C++】类的六个默认成员函数

文章目录 类的六个默认成员函数一、构造函数二、析构函数三、拷贝构造函数四、赋值运算符重载五、const成员六、取地址及const取地址操作符重载 类的六个默认成员函数 如果一个类中什么成员都没有&#xff0c;称为空类。空类中真的什么都没有吗&#xff1f;并不是&#xff0c;…

Nvidia Isaac Sim组装机器人和添加传感器 入门教程 2024(5)

Nvidia Isaac Sim 入门教程 2024 版权信息 Copyright 2023-2024 Herman YeAuromix. All rights reserved.This course and all of its associated content, including but not limited to text, images, videos, and any other materials, are protected by copyright law. …

AI穿戴设备是未来手机的终结者?中国AI商业化的未来预测

AI技术的发展正处于商业化应用的关键阶段&#xff0c;而中国在互联网时代已凭借商业化应用逆袭。AI算法大模型虽强大&#xff0c;但真正普惠民众需与设备深度结合。穿戴式智能设备就成为了新战场&#xff0c;AI算法与穿戴设备结合能释放更大工作效率。私人助理AI将成趋势&#…

如何使用k8s安装nexus3呢

百度云盘地址 链接&#xff1a;https://pan.baidu.com/s/1YN1qc2RvzTU3Ba6L_zCTdg?pwd5z1i 提取码&#xff1a;5z1i 下载后上传到本地服务器 docker load -i nexus3 创建 nexus-deployment.yaml apiVersion: apps/v1 kind: Deployment metadata:name: nexus3-deployment spec…

我的Mac疯了!居然可以生成这样的奇葩AI图片!

在当今人工智能领域&#xff0c;midjourney无疑是生成图片的王者&#xff0c;但是苦于付费才能使用&#xff0c;今天我就给大家分享一下midjourney平替stable diffusion&#xff0c;实现本地生成不逊色于midjourney的图片 效果图 先上一个我自己生成的效果(就是在我的Mac上用C…