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

2023-11-07


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 Functions Redis函数,一种新的通过服务端脚本扩展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
    

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

Redis7--基础篇1(概述,安装、卸载及配置) 的相关文章

随机推荐

  • B站数据分析岗实习生面试记录

    step1 自我介绍一下 还是需要准备以下的 不然一下子介绍自己的话 没话说 而且介绍自己不完全 step2 一道sql的笔试题目 建议刷一下题目呀 一定要刷题 掌握那些最基本的语法 step3 面试题目1 比如对B站近30天的弹幕发送量进
  • Office project 2021安装

    哈喽 大家好 今天一起学习的是project 2021的安装 Microsoft Office project项目管理工具软件 凝集了许多成熟的项目管理现代理论和方法 可以帮助项目管理者实现时间 资源 成本计划 控制 有兴趣的小伙伴也可以来
  • VALSE 文档图像智能报告整理

    目录 引言 端到端检测识别 探索检测和识别的协同作用 减少对标注的依赖 去除一些不必要的组件 文字擦除和编辑 文字辅助场景理解 视频文字擦除和文档矫正 文字识别 自监督预训练 对比学习 更高效的语言模型 手写数学公式识别 文档图像理解 视频
  • java创建数据库连接和对数据库操作的主要步骤

    Java创建数据库连接和对数据库操作的主要五个步骤如下 1 加载数据库驱动 使用 Class forName 方法加载指定的数据库驱动类 例如加载MySQL的驱动类 Class forName com mysql jdbc Driver 2
  • 基于LINUX策略路由的实现

    一 网络结构eth0 10 43 128 10 gw 10 43 0 254 gt interneleth1 61 144 64 106 gw 61 144 64 1 gt interneleth2 192 168 0 2 gw 192 1
  • python判断网络是否通

    提供两种方法 netstats py coding gbk import myarp import os class netStatus def internet on self ip 192 168 150 1 os system arp
  • 软件架构设计(四) 基于服务的架构(SOA)

    前面我们了解到了层次架构中表示层的架构分层 分为了MVC MVP MVVM等架构风格 下面我们了解一下SOA架构与微服务架构 什么是服务 服务是一种为了满足某项业务需求的操作 规则等的逻辑组合 它包含了一系列有序活动的交互 为实现用户目标提
  • Xshell 提示 “找不到匹配的host key算法”

    记录 Xshell 6 使用中遇到的 找不到匹配的host key算法 问题 问题现象 ssh远程服务器直接弹窗提示 找不到匹配的host key算法 检查点 首先查看下 sshd 的配置文件 etc ssh sshd config 确认下
  • 剑指 Offer 53 - I. 在排序数组中查找数字 I

    题目链接 53 I 在排序数组中查找数字 I 思路分析 利用二分查找即可 class Solution public int search vector
  • QT5.15.2在线安装教程(详细图文)

    一 在线安装的原因 QT对5 15以及以上版本已经停止提供离线安装包 但是 5 15以及以上版本都支持在线安装 Qt5 15以下版本可直接在Index of archive qt中下载离线安装包 二 QT账号的注册 1 打开百度 搜索QT
  • 小学科技创新项目的查新报告

    我们也经常看到这些 别人家的孩子 11岁杨荷馨 南京市六合区玉带镇中心小学伸缩式车厢卡车第六届国际发明博览会的银牌 已经申请国家专利 11岁小学生发明节能燃气灶 11岁女 发明家 造智能温控电风扇获金奖 那么现在当你家小朋友也要参加小学科技
  • 四个收敛的关系:一致收敛,点态收敛,绝对收敛,条件收敛

    一致收敛和点态收敛 先看两者定义 一致收敛 任意正数 epsilon 存在 N gt 0 N gt 0 N gt 0 当
  • VUE-CLI测试环境和打包正式环境的配置切换

    config文件夹pro d env js文件 use strict module exports NODE ENV production API ROOT http 120 79 94 143 配置开发端口 config文件夹dev en
  • 化繁为简,使用Hibernate Validator实现参数校验(一)

    目录 前言 环境配置 导入依赖 基础校验 校验注解 参数绑定 PathVariable RequestParam RequestBody Validated Valid 单参校验 对象校验 分组校验 顺序校验 前言 在之前的悦享校园的开发中
  • docker 离线安装

    目录 服务介绍 软件下载 服务配置 二进制安装docker与docker compose 服务管理命令 服务介绍 docker 是一个供开发和运维人员开发 测试 部署和运行应用的容器平台 docker compose 是一个用于运行和管理多
  • 缓存案例-架构真题(二十二)

    试题一 某大型电商平台建立一个B2B商店系统 并在全国建设了仓储中心 但是在运营过程中 发现很多跨仓储中心调货 延误运送 为此建立全国仓储系统 通过对订单的分析和挖掘 并通过大数据分析预测各类配置 降低成本 当用户通过B2B商店下单 会通过
  • Notepad++ - 缓存目录

    C Users 你的用户名 AppData Roaming Notepad backup 被360清理了 或者程序崩溃了 死机了 都可以在这里找到
  • 华为OD机试经验(A 卷 2022Q4)

    文章目录 1 汇率 2 箱子之字形摆放 3 Excel单元格数值统计 先打个小广告 在我的Hr的指导帮助下 顺利通过了机试 两轮技术面 由于今年顺利研究生上岸 所以没有进行主管面试了 向各位想去华为OD的小伙伴们推荐我的对接Hr微信 蒋虎
  • 【亲测有用】腾讯会议共享PPT,并开启演讲者模式

    出发点 腾讯会议共享PPT 开启演讲者模型 并且观看屏幕的人根本看不到你的演讲者模型 我这边Win10亲测有用 我单笔记本屏幕测试 原理解释 通过播放PPT 产生了一个全屏 可以把它理解为是扩展屏 然后切回演讲者模式的那个屏幕 可以理解为电
  • Redis7--基础篇1(概述,安装、卸载及配置)

    1 Redis概述 1 1 什么是Redis Redis REmote Dictionary Server 远程字典服务器 Remote Dictionary Server 远程字典服务 是完全开源的 使用ANSIC语言编写遵守BSD协议