Redis7--基础篇1(概述,安装、卸载及配置)

news2024/12/26 22:51:18

1. Redis概述

1.1 什么是Redis

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

1.2 Redis之父

Redis之父Salvatore Sanfilippo,一名意大利程序员,大家更习惯称呼他Antirez
Github:https://github.com/antirez
个人博客:http://antirez.com/latest/0

1.3 Redis能做什么(主流功能与应用)

  • 分布式缓存
    与传统数据库关系(mysql)
    Redis是key-value数据库(NoSQL一种),mysql是关系数据库
    Redis数据操作主要在内存,而mysql主要存储在磁盘
    Redis在某一些场景使用中要明显优于mysql,比如计数器、排行榜等方面
    Redis通常用于一些特定场景,需要与Mysql一起配合使用
    两者并不是相互替换和竞争关系,而是共用和配合使用
    在这里插入图片描述

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

  • 高可用架构搭建
    单机、主从、哨兵、集群

  • 缓存穿透、击穿、雪崩

  • 分布式锁

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

  • 实现排行榜、点赞等功能

  • 优势
    性能极高 - Redis读的速度是110000次/秒,写的速度是81000次/秒。
    数据类型丰富,不仅仅支持k-v类型的数据,同时还提供了list、set、zset、hash等数据结构的存储。
    支持持久化,可将内存中的数据存入写入到磁盘中。
    支持数据备份,即master-slaver模式的数据备份

  • 一图流概括介绍:
    在这里插入图片描述

  • 总结
    在这里插入图片描述

1.4 下载、安装及参考资料

下载地址:
https://redis.io
在这里插入图片描述

http://www.redis.cn/
在这里插入图片描述

https://redis.io/download/
在这里插入图片描述
redis-7.0.0.tar.gz

历史版本:
在这里插入图片描述

文档下载:
https://www.redis.com.cn/documentation.html
在这里插入图片描述

Redis源码地址:
https://github.com/redis/redis
在这里插入图片描述

Redis在线测试:
https://try.redis.io/

Redis在线参考:
http://doc.redisfans.com/

1.5 Redis迭代演化和Redis7新特性浅谈

  • 重要版本
    在这里插入图片描述
    5.0版本是直接升级到6.0版本,对于这个激进的升级,Redis之父antirez表现得很有信心和兴奋,所以第一时间发文来阐述6.0的一些重大功能"Redis 6.0.0 GA is out!"。
    随后Redis再接再厉,直接王炸Redis7.0—2023年爆款
    2022年4月27日Redis正式发布了7.0更新(其实早在2022年1月31日,Redis已经预发布了7.0rc-1,经过社区的考验后,确认没重大Bug才会正式发布)

  • 学习视频
    哔哩哔哩查找尚硅谷之Redis教学视频

  • 新特性
    在这里插入图片描述
    Redis Functions
    在这里插入图片描述
    Client-eviction
    在这里插入图片描述
    Muti-part AOF
    在这里插入图片描述
    ACL V2
    在这里插入图片描述
    新增命令
    在这里插入图片描述
    listpack代替ziplist
    listpack 是用来替代 ziplist 的新数据结构,在 7.0 版本已经没有 ziplist 的配置了(6.0版本仅部分数据类型作为过渡阶段在使用)
    在这里插入图片描述
    底层性能提升(与编码关系不大)

总体概述:
大体和之前的redis版本保持一致和稳定,主要是自身底层性能和资源利用率上的优化和提高,如果你生产上系统稳定,不用着急升级到最新的redis7版本,当然,O(∩_∩)O哈哈~,如果你是从零开始的新系统,直接上Redis7.0-GA版。

多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更加优秀更好的内存统计报告
如果不为了API向后兼容,我们将不再使用slave一词…(政治正确)

2. 安装、卸载、配置

可以安装到购买的各种云服务器,或者安装到虚拟机。默认Redis安装到Linux系统下,因为不会有企业将Redis安装到Windows系统下。

2.1 检查安装环境

Linux系统安装Redis必须具备GCC编译环境

查看是否有gcc编译器

gcc -v

安装gcc编译器

yum -y install gcc-c++

在这里插入图片描述

2.2 安装步骤

  • 下载安装包并放入/opt目录下
wget https://download.redis.io/releases/redis-7.0.0.tar.gz

在这里插入图片描述

  • 解压缩
tar -zxvf redis-7.0.0.tar.gz

在这里插入图片描述

  • 执行make命令进行编译
make && make install

在这里插入图片描述
在这里插入图片描述

2.3 卸载步骤

  • 停止redis-server服务
    在这里插入图片描述
  • 删除 /usr/local/lib 目录下与redis相关的文件
ls -l /usr/local/bin/redis-*
rm -rf /usr/local/bin/redis-*

在这里插入图片描述

2.4 启动服务

  • 默认的安装目录为/usr/local/bin/,类似于C:\Program Files
    • redis-benchmark
      性能测试工具,服务启动后运行该命令,查看本机性能
    • redis-check-aof
      修复有问题的AOF文件
    • redis-check-rdb
      修复有问题的RDB文件
    • redis-cli
      客户端服务
    • redis-sentinel
      Redis集群服务
    • redis-server
      Redis服务器启动服务
  • 定制启动配置文件
    • 备份启动配置文件
      在这里插入图片描述
    • 修改配置文件
      • redis.conf配置文件,改完后确保生效,记得重启,记得重启
      • 默认daemonize no 改为 daemonize yes
      • 默认protected-mode yes 改为 protected-mode no
      • 默认bind 127.0.0.1 改为 直接注释掉(默认bind 127.0.0.1只能本机访问)或改成本机IP地址,否则影响远程IP连接
      • 添加redis密码 改为 requirepass 你自己设置的密码
        在这里插入图片描述
        在这里插入图片描述
        在这里插入图片描述
  • 执行启动命令
    redis-server /myredis/redis7.conf
    
  • 连接Redis数据库并验证
    #登陆
    redis-cli -a 123456  -p 6379
    #验证
    127.0.0.1:6379> ping
    
    在这里插入图片描述

2.5 关闭服务

  • 单实例关闭
    redis-cli -a 123456 shutdown
    
  • 多实例关闭
    redis-cli -a 123456 -p 6379 shutdown
    

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

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

相关文章

运营岗位需要一个内部知识库吗?

在运营岗位中,一个内部知识库是非常有价值的。运营岗位涉及到许多不同的任务和责任,需要掌握大量的专业知识和最佳实践。一个内部知识库可以帮助运营团队更好地管理和共享这些知识,提高工作效率和质量。 内部知识库对运营岗位的价值和应用场…

Eclipse安装FTP连接工具

查看Eclipse版本 Eclipse 安装串口终端工具_哭哭啼的博客-CSDN博客 安装 选择您的版本的插件发布站点: 在过滤器字段中,键入"remote".选择Mobile and Device Development,并选择 点击"下一步",然后接受条款.它现在应该下载并安装.…

SAP物料主数据归档详解(物理删除)

平时在操作系统过程中经常会不小心创建出很多无用的物料主数据,但是系统只能通过MM06打上删除标记,但是物料最终在系统中还是可以查询到的。 相信各位大顾问们肯定被用户问过,有没有办法把物料或者是业务数据从物理上删除。顾问们的回答肯定…

【算法】Java-使用数组模拟单向链表,双向链表

目录 试题1:实现一个单链表,并实现以下功能: 试题2:实现一个双链表,并实现以下功能 思路总结: 什么情况下可能涉及到用数组实现链表呢? 在学习时了解到了可以用数组模拟链表,使其…

【LInux编译器gcc/g++】gcc使用方法和动静态库相关概念

目录 一.前言 二.源代码的翻译环境 三.gcc相关指令 四.动静态库 1.什么是库? 2.库的命名 3.库的链接方式 4.动静态链接的优缺点 5.小结 一.前言 在Windows系统上我们常用VisualStudio来进行C/C开发,VS并不是一款单一的软件,而是集成…

UI设计模式是什么?有哪些常用的?

UI设计模式是针对常见的用户界面问题提出的解决方案。当解决方案得到验证时,它经常被使用,最终演变成可重复使用的设计模式。 设计师可以根据不同的网站功能类型选择使用相应的网站UI设计模式,从而创建一致高效的网站UI界面。 本文推荐8种常…

选择排序——直接选择排序

直接选择排序:(以重复选择的思想为基础进行排序) 1、简述 顾名思义就是选出一个数,再去抉择放哪里去。 设记录R1,R2…,Rn,对i1,2,…,n-1,重复下…

【MMDetection】bug记录

bug1: if env_cfg.get(cudnn_benchmark): AttributeError: NoneType object has no attribute get 解决办法: 配置文件缺少了env_cfg信息,需要在config文件中添加,如以下内容: env_cfg dict(cudnn_benchmarkFalse…

Java 使用 EMQX 实现物联网 MQTT 通信

一、介绍 1、MQTT MQTT(Message Queuing Telemetry Transport, 消息队列遥测传输协议),是一种基于发布/订阅(publish/subscribe)模式的"轻量级"通讯协议,该协议构建于TCP/IP协议上,由IBM在1999年发布。MQTT最大优点在于&#xff…

Netty核心原理:一、基础入门-01:初入JavaIO之门BIO、NIO、AIO实战练习

文章目录 一、前言介绍1.1 BIO:同步阻塞I/O模式1.2 NIO:同步非阻塞I/O模式1.3 AIO:异步非阻塞I/O模式 二、代码实现2.1 工程结构2.2 BIO:同步阻塞I/O实现2.2.1 BIO处理器2.2.2 BIO适配器2.2.3 BIO客户端处理器2.2.4 BIO客户端2.2.…

计算机网络第五章——传输层(上)

早知如此绊人心,何如当初莫相识 文章目录 前言 前言 虽然说是手机和手机之间的通信但是其实是手机之间的进程和进程之间的通信,所以这一章主要是研究进程之间通信的问题,在计算机网络中有一个重要的问题,在进行数据通信和资源共享…

【分享】golang windows 运行报错 undefined: syscall.SIGUSR1

在跟着煎鱼大佬学习 Golang-gin的时候,"在优雅的重启服务篇" ,为了gin服务的热更新,采用了 endlessfresh的方案,安装endless后无法在windows本地调试,然后报错。 (优雅的重启服务-地鼠文档优雅的重启服务-我不怎么喜欢左写写&#…

linux内核模块编译方法之模块编程详解

文章目录 一、模块传参二、模块依赖三、内核空间和用户空间四、执行流五、模块编程与应用编程的比较六、内核接口头文件查询总结 本期和大家主要分享的是驱动开发内核编译过程中对于模块是如何设计的,进行了详细的分享,从模块传参、模块依赖一直到内核空…

楼顶空地适合建造气膜体育馆吗?

众所周知,传统建筑的荷载太大,出于安全考虑,是不适合继续在楼顶加盖传统结构体育馆的,但是,气膜体育馆作为一种装配式建筑,它是可以在城市高空上建造一个轻盈又新颖独特的全天候气膜馆。 气膜体育馆作为一种…

小黑自己在家尝试涮牛排,肚子又开始了新一轮的胀气,喝到了酱香拿铁并烫了纹理发型体验一把的leetcode之旅:123. 买卖股票的最佳时机 III

动态规划1 class Solution:def maxProfit(self, prices: List[int]) -> int:# 数组长度n len(prices)if n < 2:return 0# 动态规划变量# 第一次买的价格first_price prices[0]# 第一次卖的收益first_cell 0# 第二次买的价格second_price prices[0]# 第二次卖second_…

STM32H750 HAL CUBEMX 时钟失败及死机无法下载问题解决

芯片采样电压设置&#xff0c;否则 无法运行 解决死机问题 设置swd 模式 短接 boot0 —vcc 3.3v即可正常下载

驱动开发,stm32mp157a开发板的led灯控制实验

1.实验目的 编写LED灯的驱动&#xff0c;在应用程序中编写控制LED灯亮灭的代码逻辑实现LED灯功能的控制&#xff1b; 2.LED灯相关寄存器分析 LED1->PE10 LED1亮灭&#xff1a; RCC寄存器[4]->1 0X50000A28 GPIOE_MODER[21:20]->01 (输出) 0X50006000 GPIOE_ODR[10]-&g…

5. HBase必知必会之理论进阶篇

HBase必知必会之理论进阶篇 1.1 集群搭建以及规模预测1.1.1 HBase集群搭建1.1.2 HBase集群规划 1.2 HBase重要的概念1.2.1 snapshot1.2.2 region 切分1.2.3 RIT1.2.4 HBase读优化1.2.4.1 客户端优化1.2.4.2 服务端优化1.2.4.3 hdfs 优化 1.2.5 HBase写优化1.2.5.1 客户端优化1.…

Linux centos7 bash编程训练__打印各类形状

利用for循环&#xff0c;打印各种不同的三角形、矩形和菱形。 主要是fort循环嵌套使用&#xff0c;及条件判断等。 因方法简单&#xff0c;不作更多解释&#xff0c;部分注释可以帮助初学者掌握代码。 下面列出代码&#xff0c;供参考。 #! /bin/bash ## 打印输出各种*型形…

中企出海,用火山引擎DataTester开启增长第一步

更多技术交流、求职机会&#xff0c;欢迎关注字节跳动数据平台微信公众号&#xff0c;回复【1】进入官方交流群 今年 Google 宣布其提供的A/B测试工具 Optimize 将在2023年9月30号停止服务。在全球化浪潮席卷下&#xff0c;越来越多的中国企业正在加速走向全球市场&#xff0c;…