【Redis7】--1.概述、安装和配置

news2024/10/12 12:28:27

文章目录

  • 1.Redis概述
    • 1.1Redis是什么
    • 1.2Redis与MySQL的关系
    • 1.3Redis功能
    • 1.4Redis优势
  • 2.Redis的安装和配置

1.Redis概述

1.1Redis是什么

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

1.2Redis与MySQL的关系

按照二八原则,主流的应用对系统的请求80%都是查询,20%是增删改,客户端查询数据先查询Redis数据库,如果命中了则将查询结果返回,如果没有命中再去MySQL数据库查询,然后将数据返回并且将数据写入Redis数据库,下次再查询该数据时就可以从Redis数据库中获取

image-20230907205712232

1.3Redis功能

  • 缓存

Redis常用于作为高速缓存,将常用的数据存储在内存中,提高访问速度和响应时间,减轻后端数据库的压力。Redis支持多种数据结构,可以根据数据的类型和特点选择合适的数据结构进行缓存。

  • RDB和AOF持久化

redis支持异步将内存中的数据写到硬盘上,同时不影响继续服务。

即使设备断电了,数据也不会丢失,重启后重新从硬盘恢复数据。

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

支持大规模数据存储和高并发访问。

  • 解决缓存穿透、击穿、雪崩

1.对查询不存在的数据请求进行过滤,比如采用Bloom Filter进行缓存预热或者对查询请求进行缓存穿透保护

2.对于热点数据的访问,可以采用分布式锁等方法对缓存进行保护,避免缓存击穿

3.对于缓存雪崩,可以采用缓存预热、缓存过期时间随机化、缓存数据的多级缓存等方法进行缓解

  • 分布式锁

Redis支持原子操作和过期时间等特性,可以用于实现分布式锁

可以保证在分布式系统中同一时刻只有一个客户端可以持有锁,从而保证共享资源的互斥访问

例如,可以使用Redis的SETNX命令实现基于key的锁,使用Lua脚本实现基于value的锁

  • 消息队列

redis提供了多种队列模式:List队列、Pub/Sub队列、Stream队列

  • 计数器和排行榜

Redis支持原子操作,可以用于实现计数器和排行榜功能

例如,可以使用Redis的INCR命令实现计数器功能,使用ZADD命令实现有序集合排行榜功能

除了以上几个方面,Redis还可以用于实现限流、地理位置服务、实时统计等应用场景。总之,Redis是一个功能丰富、性能优秀的内存数据库,适合于需要高性能、高可用、高并发的应用场景。

image-20230907211204709

1.4Redis优势

  • 性能极高 -Redis能读的速度是110000次/秒,写的速度是81000次/秒
  • Redis数据类型丰富,不仅仅支持简单的key-value类型的数据,同时还提供list,zset,set,hash等数据结构的存储
  • Redis支持数据的持久化,可以将内存中的数据保存在磁盘中,重启的时候可以再次加载进行使用
  • Redis支持数据的备份,即master-slave模式的数据备份

image-20230907211314500

2.Redis的安装和配置

Redis官网下载地址:https://redis.io/download/
Redis官方中文文档:https://www.redis.com.cn/documentation.html
Redis命令使用手册官方版:https://redis.io/commands/
Redis命令使用手册中文版:http://www.redis.cn/commands.html
Redis命令参考手册:http://doc.redisfans.com/
Redis版本第二位数字如果是偶数,就是稳定版,如果是奇数,就是激进版

(1)检测Linux安装环境

Linux环境安装Redis必须先具备gcc编译环境,gcc是linux下的一个编译程序,是C程序的编译工具。

gcc -v	# 查看是否安装了gcc
yum -y install gcc-c++	# 若是没有安装可以使用此命令安装

(2)下载Redis

下载redis-7.0.10.tar.gz,地址:https://redis.io/download/,下载后使用工具将它传到Linux系统的/opt目录下,然后解压。对于第三方软件,一般都安装在/opt目录下。

tar -zxvf redis-7.0.10.tar.gz	# 解压到当前目录

(3)安装redis

这里是redis的安装目录,进入解压目录执行make命令先编译后安装

cd redis-7.0.10	# 切换到解压目录
make	# 编译
make install	# 安装

(4)查看redis服务安装目录

这里是redis服务的安装目录,redis服务默认安装目录在/usr/local/bin

装在这个目录下的文件,相当于配置了PATH变量,在任何目录都可以启动redis服务。

Linux下的/usr/local类似windows系统的C:\Program Files。

image-20230907215033829

redis-benchmark:性能测试工具
redis-check-aof:修复有问题的aof文件
redis-check-dump:修复有问题的rdb文件
redis-cli:redis提供的命令行客户端
redis-sentinel:redis的哨兵启动脚本
redis-server:redis的服务端启动脚本

(5)修改配置文件

回到解压目录,对redis.conf文件进行修改

image-20230907220846554

修改配置文件前,先对文件进行备份

mkdir /myredis	#创建目录
cp redis.conf /myredis/redis7.conf	# 将配置文件复制到myredis目录并命名为redis7.conf

修改redis.conf配置文件,改完后确保生效,记得重启,记得重启

  • 默认daemonize no 改为 daemonize yes,表示开启后台启动
  • 默认protected-mode yes 改为 protected-mode no,需要别人来连接redis服务器的话需要改成no
  • 默认bind 127.0.0.1 直接注释掉(默认bind 127.0.0.1只能本机访问)或改成主机IP地址,否则影响远程IP连接
  • 添加redis密码,配置 requirepass 123456 即可(123456为设置的密码)

(6)启动redis服务

启动配置文件,redis-server直接启动是前台启动,后面加上配置文件启动是后台启动。

任意目录输入redis-server都可以直接启动redis服务。

不过这样启动redis需要一直处在这个界面,也就是前台启动,不能进行其他操作,我们希望它在后台运行,后台启动需要指定配置文件

redis-server /opt/redis-7.0.10/redis.conf	# 指定配置启动:后台启动redis服务
ps -ef | grep redis		# 通过则个指令可以查看正在运行的redis服务

image-20230907220746045

(7)连接redis服务

通过redis的redis-cli可执行程序来连接redis服务

redis-cli -a 123456 -p 6379	# -a表示输入密码,-p表示端口号,本机访问可以省略不写,默认是6379
ping	# 输入ping后回车输出pong说明连接成功
set key1 helloworld		# 设置键key1的值为helloworld
get key1		# 获取key1的值
quit	# 输入quit回车退出前台客户端,服务并没有退出

image-20230907221053266

也可以不输入 -a 然后输入密码,可以直接进去 输入 auth 【密码】进行登录验证

image-20230907221137454

(8)停止redis服务

利用redis-cli来执行 shutdown 命令停止 Redis 服务,因为之前配置了密码,因此需要通过 -u 来指定密码

# 单实例关闭
redis-cli -a 123456 shutdown 	
#多实例关闭,指定端口关闭
redis-cli -a 123456 -p 6379 shutdown
# 也可以使用   kill -9 进程号  终止对应的进程

image-20230907222404008

(9)redis卸载

ls -l /usr/local/bin/redis-*
rm -rf /usr/local/bin/redis-*

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

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

相关文章

算法-26. 删除有序数组中的重复项-⭐

给你一个 升序排列 的数组 nums ,请你 原地 删除重复出现的元素,使每个元素 只出现一次 ,返回删除后数组的新长度。元素的 相对顺序 应该保持 一致 。然后返回 nums 中唯一元素的个数。 考虑 nums 的唯一元素的数量为 k ,你需要做…

【数据分析】Python:处理缺失值的常见方法

在数据分析和机器学习中,缺失值是一种常见的现象。在实际数据集中,某些变量的某些条目可能没有可用的值。处理缺失值是一个重要的数据预处理步骤。在本文中,我们将介绍如何在 Pandas 中处理缺失值。 我们将探讨以下内容: 什么是缺…

php将数组中的最后一个元素放到第一个

array_unshift($firstStepResult, array_pop($firstStepResult)); 转换之后

spring spring-boot spring-cloud spring-cloud-alibaba之间版本对应关系

spring 版本与 jdk 的对应关系 https://github.com/spring-projects/spring-framework/wiki/Spring-Framework-Versions 从 spring 6.0 开始使用 jdk 17 进行编译 对应的相关 servlet 容器(tomcat、undertow、jetty等)的 servlet 规范转移到 eclipse&…

算法-27.移除元素-⭐

给你一个数组 nums 和一个值 val,你需要 原地 移除所有数值等于 val 的元素,并返回移除后数组的新长度。 不要使用额外的数组空间,你必须仅使用 O(1) 额外空间并 原地 修改输入数组。 元素的顺序可以改变。你不需要考虑数组中超出新长度后面…

MiniDump

一、minidump 模块集成 // .pro QT - guiCONFIG c11 console CONFIG - app_bundle# The following define makes your compiler emit warnings if you use # any Qt feature that has been marked deprecated (the exact warnings # depend on your compiler). Please consul…

想兼职?学网络安全,钱赚到你手软

前言 疫情过后,现在的经济形式并不好,所以有很多人想在本职工作以外找一份兼职,亦或者担心自己被裁员,想先学一门技术,从而提高自己的抗风险能力,这没有比网络安全更适合的了。如果有基础的小伙伴完全可以…

01深度学习目标检测引入

目标检测是计算机视觉领域的一个重要任务,旨在从图像或视频中准确地检测和定位特定的目标物体。 一、目标检测问题定义 目标检测是在图片中对可变数量的目标进行查找和分类。 二、目标检测过程中的常见的问题 目标种类和数量问题目标尺度问题外在环境干扰问题 三…

IDEA显示val,var的推断类型的设置

在java中val,var可以减少繁琐的代码量,但是IDEA默认关掉自动类型,导致使用val,var表示的不能一言判别类型,并且不能显示点入查看类型的详情因此需要在idea中设置,能够自动显示推断类型。 步骤1 Setting--->editor…

网络安全(黑客)工具大全

还是一句话,功夫再高,也怕菜刀 首先,恭喜你发现了宝藏。 本文章集成了全网优秀的开源攻防武器项目,包含: 信息收集工具(自动化利用工具、资产发现工具、目录扫描工具、子域名收集工具、指纹识别工具、端…

CSP 202112-1 序列查询

答题 这道题不难,但如果直接去实现查询f(x)的话,算法效率会非常低 我们直接观察样例,15(5-2)*1(8-5)*2(10-8)*3 所以我们可以写出下面程序 #i…

无涯教程-JavaScript - IMSUM函数

描述 IMSUM函数以x yi或x yj文本格式返回两个或多个复数的和。当添加复数时,实数和虚数系数分别相加,即找到两个复数a bi和c di的和的方程为- (a bi)(c in)(a c)(b d)我 语法 IMSUM (inumber1, [inumber2] ...)争论 Argument描述Required/OptionalInumber11 to 25…

css relative 和absolute布局

1、relative和absolute内部的元素都是相对于父容器,若父容器没有指定为relative,则默认为整个文档视图空间,absolute可以重叠元素,relative则不行。relative意味着元素的任意属性如left和right都是相对于其他元素的。absolute则相…

二叉树(上)

“路虽远,行则将至” ❤️主页:小赛毛 目录 1.树概念及结构 1.1树的概念 1.2 树的相关概念 1.3 树的表示(树的存储) 2.二叉树概念及结构 2.1概念 2.2现实中的二叉树 2.3 特殊的二叉树: 2.4 二叉树的性质 3.二叉树的顺…

安全基础 --- 原型链污染

原型链 大部分面向对象的编程语言,都是通过“类”(class)实现对象的继承。传统上,JavaScript 语言的继承不通过 class,而是通过“原型对象”(prototype)实现 1、prototype 属性的作用 JavaScri…

【云原生进阶之PaaS中间件】第一章Redis-1.4过期策略

1 设置带过期时间的 key # 时间复杂度:O(1),最常用方式 expire key seconds# 字符串独有方式 setex(String key, int seconds, String value)除了string独有设置过期时间的方法,其他类型都需依靠expire方法设置时间&a…

高效数据湖构建与数据仓库融合:大规模数据架构最佳实践

文章目录 数据湖和数据仓库:两大不同理念数据湖数据仓库 数据湖与数据仓库的融合统一数据目录数据清洗和转换数据安全和权限控制数据分析和可视化 数据湖与数据仓库融合的优势未来趋势云原生数据湖自动化数据处理边缘计算与数据湖融合 结论 🎉欢迎来到云…

盲盒游戏的盈利原理

盲盒游戏,一种极具不确定性的娱乐方式,以其独特的魅力和盈利模式吸引了大量消费者和商家的关注。本文将从盲盒App的盈利模式、随机性、极低成本和超高复购率四个方面,深入剖析其盈利原理。 一、盈利模式 盲盒App的盈利模式主要是通过…

Kafka3.0.0版本——消费者(Range分区分配策略以及再平衡)

目录 一、Range分区分配策略原理1.1、Range分区分配策略原理的示例一1.2、Range分区分配策略原理的示例二1.3、Range分区分配策略原理的示例注意事项 二、Range 分区分配策略代码案例2.1、创建带有4个分区的fiveTopic主题2.2、创建三个消费者 组成 消费者组2.3、创建生产者2.4、…

学会用命令行创建uni-app项目并用vscode开放项目

(创作不易,感谢有你,你的支持,就是我前行的最大动力,如果看完对你有帮助,请留下您的足迹) 目录 创建 uni-app 项目 命令行创建 uni-app 项目 编译和运行 uni-app 项目: 用 VS Code 开发 uni…