首页 > 数据库 >Redis介绍

Redis介绍

时间:2024-08-16 12:51:30浏览次数:13  
标签:文件 redis ziplist Redis 介绍 内存 maxmemory

Redis

一、介绍

1.1 基本了解

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

1.2 功能

  • 分布式缓存,挡在MySQL数据库之前的带刀护卫在这里插入图片描述

    与mysql相比

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

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

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

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

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

  • 内存存储和持久化(RDB+AOF),redis支持异步将内存中的数据写到硬盘上,同时不影响继续服务

  • 高可用架构搭配

    • 单机
    • 主从
    • 哨兵
    • 集群
  • 缓存穿透、击穿、雪崩

  • 分布式锁

  • 队列

    • Reids提供list和set操作,这使得Redis能作为一个很好的消息队列平台来使用
    • 我们常通过Reids的队列功能做购买限制。比如到节假日或者推广期间,进行一些活动,对用户购买行为进行限制,限制今天只能购买几次商品或者一段时间内只能购买一次。也比较适合适用。
  • 排行榜+点赞

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

    在这里插入图片描述

1.3 优势

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

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

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

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

    • 生成dump.rpb文件(可以在配置文件中改) 默认生成在redis.conf同级目录

    在这里插入图片描述

1.4 Redis7新特性

  • Redis Functions

在这里插入图片描述

  • Client—eviction

在这里插入图片描述

  • AOF

在这里插入图片描述

  • ACL v2

在这里插入图片描述

  • 在这里插入图片描述

  • listpack替代ziplist

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

多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-clients 1g maxmemory-clients 10%
listpack紧凑列表调整listpack是用来替代 ziplist 的新数据结构,在7.0版本已经没有ziplist 的配置了(6.0版本仅部分数据类型作为过渡阶段在使用)listpack已经替换了ziplist类似 hash-max-ziplist-entries的配置
访问安全性增强ACLV2在redis.conf配置文件中,protected-mode默认为yes,只有当你希望你的客户端在没有授权的情况下可以连接到Redis server的时候可以将protected-mode设置为no
Redis FunctionsRedis函数,一种新的通过服务端脚本扩展Redis的方式,函数与数据本身一起存储。简言之,redis自己要去抢夺Lua脚本的饭碗
RDB保存时间调整将持久化文件RDB的保存规则发生了改变,尤其是时间记录频度变化
命令新增和变动Zset(有序集合)增加ZMPOP、BZMPOP、ZINTERCARD 等命令 Set(集合)增加 SINTERCARD命令 LIST (列表)增加 LMPOP、BLMPOP,从提供的键名列表中的第一个非空列表键中弹出一个或多个元素。
性能资源利用率、安全、等改进自身底层部分优化改动,Redis核心在许多方面进行了重构和改进 主动碎片整理V2:增强版主动碎片整理,配合Jemalloc版本更新,更快更智能,延时更低 HyperLogLog改进:在Redis5.0中,HyperLogLog算法得到改进,优化了计数统计时的内存使用效率,7更加优秀更好的内存统计报告

标签:文件,redis,ziplist,Redis,介绍,内存,maxmemory
From: https://blog.csdn.net/qq_55846232/article/details/141255120

相关文章

  • vue-router,vue3介绍,vue3快速创建项目,常用api,生命周期,setup的特殊写法
    Ⅰvue-router【一】路由守卫#1路由守卫是什么 是否登录,登录后才能访问,没登录重定向到login作用:对路由进行权限控制#2全局守卫、独享守卫、组件内守卫使用importElementfrom'element-ui'//全局路由守卫-->前置路由守卫router.beforeEach((to,fr......
  • redis启动失败报错:Job for redis.service failed because the control process exited
    问题描述启动报错如下:查看redis的启动信息:systemctlstatusredis.service或journalctl-xe由提示可以看不是配置文件,内存等原因造成的。解决方案原因:linux的一个安全子系统(SELinux)阻止了服务的启动。查看SELinux的工作模式cat /etc/selinux/configSELinu......
  • type-C接口的应用和PD取电快充协议的介绍
    USB快充控制芯片又称为快充诱骗芯片,是一种集成电路,主要用来和充电器内部的供电协议芯片进行通讯握手快充协议。它一般应用在Type-C接口的控制电路中,可以和充电器通讯,获取充电器的快充电压。电路中使用这种Type-C控制芯片后,可以自适应市面上各家的快充协议充电器,使其输出快充电......
  • deepin V23 Release 安装与功能介绍!!!
    原文链接:deepinV23Release安装与功能介绍!!!Hello,大家好啊!2024年8月15日,deepin正式发布了最新版操作系统——deepinV23。今天,我将为大家带来一篇关于deepinV23的安装及功能介绍的文章。deepin作为一款广受欢迎的国产Linux发行版,以其美观的界面和良好的用户体验而著称。V2......
  • Redis数据结构ZipList详解、ZipList的连锁更新问题
    ZipListZipList是一种特殊的“双端链表”,由一系列特殊编码的连续内存块组成。可以在任意一端进行压入/弹出操作,并且该操作的时间复杂度为O(1)。属性类型长度用途zlbytesuint32_t4字节记录整个压缩列表占用的内存字节数zltailuint32_t4字节记录压缩列表表尾节点距离压......
  • Redis数据结构:动态字符串SDS、Intset、Dict详解
    动态字符串:我们都知道Redis中保存的Key是字符串,value往往是字符串或者字符串的集合。可见字符串是Redis中最常用的一种数据结构。不过Redis没有直接使用C语言中的字符串,因为C语言字符串存在很多问题:获取字符串长度的需要通过运算非二进制安全不可修改Redis构建了一种新的......
  • (路由卷1)-1课程介绍_网络架构
    企业架构campus园区网datacenter数据中心branch分支机构teleworker远程办公人员网络模型access接入层distribution分布层做策略core核心层高速数据转发企业符合网络模型enterprisecampus企业园区enterpriseedge企业边缘serviceprovideredge服务提供商边缘网络......
  • (路由卷1)-16-OSPF基础知识介绍
    ospf高级features链路状态路由协议路由变化收敛速度比较快(传递lsa)支持vlsm/cidr/不连续子网触发更新-快速响应网络变化每30分发定期更新叫链路状态刷新支持区域(area)划分并有三张表没有跳数的限制使用tag(路由标记)可跟踪外部路由适合多厂商大型网络设计方案使用组播和......
  • Git零基础入门与常见命令介绍
    Git 是一个开源的分布式版本控制系统,用于高效地处理任何大小的项目。它由LinusTorvalds为了帮助管理Linux内核开发而开发的开放源码软件。与常用的版本控制工具(如CVS、Subversion)不同,Git采用了分布式版本库的方式,不需要服务器端软件支持。目录1.安装Git2.基本命令介绍2......
  • 【Django开发】前后端分离django美多商城项目第1篇:欢迎来到美多 项目主要页面介绍【附
    本教程的知识点为:项目准备项目准备配置1.修改settings/dev.py文件中的路径信息2.INSTALLED_APPS3.数据库用户部分图片1.后端接口设计:视图原型2.具体视图实现用户部分使用Celery完成发送判断帐号是否存在1.判断用户名是否存在后端接口设计:用户部分......