【Redis】Redis的概念 | 特性 | 应用场景 | 安装 | 客户端

news2024/9/20 14:30:32

文章目录

  • Redis
    • 一、认识Redis
    • 二、Redis的特性
    • 三、Redis的应用场景
    • 四、安装Redis
    • 五、Redis的客户端

Redis

一、认识Redis

  • Redis是一个开源的,在内存中存储数据。在分布式系统中更有优势。如果是单机环境下,直接通过变量存储数据比用Redis更有优势。在分布式系统中,要想多个服务器共享同一份数据,同时又想让数据在内存中,就可以选择Redis.

  • 进程是具有隔离性的,分布式系统会设计到多个进程。多个进程在不同的主机上,要想直接访问其他进程内存当中的变量,突破进行的隔离性,就极为困难。Redis就相当于对这样是需求,进行了封装。通过进程之间的通信(网络 )

  • 因此,Redis就是基于网络,将自己内存中的变量,提供给本机别的进程、别的主机的进程来使用。

  • Redis可以作为数据库来使用,要MySQL快很多(MySQL最大的缺点,就是访问速度慢)。但是相对的,Redis的存储空间是有限的。要同时解决存储量和访问速度的问题,可以将Redis和MySQL结合使用。也就是说,用Redis来作为MySQL的Cache。将一些热点数据用Redis来存储,将全量数据用MySQL来存储。

    二八原则:20%的热点数据可以满足80%的访问需求

    虽然利用了Redis速度快和MySQL存储多的特点,但是提高了系统的复杂度。同时,如果发生数据的修改,要考虑Redis和MySQL的数据同步问题。世上亦无两全法,没有银弹!要根据场景来进行选择。

  • Redis的初心是用来作为 消息中间件(消息队列),是分布式系统下的生产者-消费者模型。

二、Redis的特性

  • 是非关系型数据库:在内存中通过“键值对”来存储数据。(key都是String ,value是hash/list等数据结构)

  • 可编程操作:简单的交互命令进行操作、Lua脚本,来批量执行

  • 可扩展性:Redis提供了一组API,可以在原有的基础上进行扩展(C/C++/Rust 语言编写Redis扩展 。本质上是一个动态链接库)

  • 持久化:Redis是把数据存储在内存上。而内存上的数据是“易失”的。Redis会把数据存储一份在硬盘上。以内存为主,硬盘为辅。硬盘相当于对数据进行了备份,如果Redis重启,就会加载硬盘中备份的数据,使内存恢复到重启前的状态。

  • 支持集群:水平扩展,类似于分库分表。一个Redis存储的空间有限,引入多个主机,部署多个Redis节点,每个Redis存储数据的一部分。

  • 高可用:冗余/备份 。Redis自身支持“主从”结构。从节点相当于主节点的备份

  • 速度快:

    1.数据存在硬盘中,比访问硬盘快。

    2.Redis的核心功能都是比较简单的逻辑。

    3.Redis使用了IO多路复用的方式(epoll)用一个线程来管理很多个Socket

    4.Redis使用的是单线程模型(高版本引入了多线程)。单线程模型,减少了不必要线程之间的竞争开销

三、Redis的应用场景

1.Redis可以作为数据库,存的是全量数据。

2.Redis作为缓存,存的是部分数据,全量数据以MySQL为主。

3.会话存储。1.负载均衡器把同一个用户的请求分配到同一个机器上。2.把会话数据独立出来,放在独立的机器上存储(Redis)。后续每个应用服务器在读取会话时,先访问Redis.不管请求到哪个应用服务器上,都是从Redis拿到的会话。如果应用服务器重启,会话数据就不会丢失。(也不是不能丢,叫用户再登录一下)

4.作为消息队列(服务器)实现网络版本的生产者-消费者模型。

1,解耦合

2.削峰填谷

四、安装Redis

版本:Redis5 Linux版本:Ubuntu

1.切换root用户 su

2.apt命令来搜索Redis : apt search redis

3.安装 :apt install redis

4.验证:netstat -anp | grep redis Redis的默认端口是6379

在这里插入图片描述

5.发现当前是环回IP,需要手动修改配置文件,将IP进行修改。绑定环回IP,意味着只能由当前主机来访问,跨主机就访问不了了。

cd /etc/redis/redis.conf
//找到配置文件
bind 后面的127.0.0.1 ::1  改为 0.0.0.0 ::1

protected-mode yes 改为 no

6.重启服务器

service redis-server restart

7.使用Redis自带的客户端来连接服务器

redis-cli     ping ->pong 表示正常工作    ctrl+d 退出redis客户端

五、Redis的客户端

  • Redis也是一个客户端-服务器结构

客户端:

1.自带的命令行客户端 redis-cli 命令

redis-cli -h 127.0.0.1 -p 6379

2.图形化界面客户端(桌面程序、Web程序)

3.基于redis的api自行开发客户端

点击移步博客主页,欢迎光临~

偷cyk的图

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

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

相关文章

通信系统的均衡技术

1、摘要 在通信系统中,信号从发送端发出,经过信道,到达接收端,而在传输的过程中,信号会发生失真,产生失真的原因有很多,包括阻抗不匹配,干扰等。为了优化信号质量,需要进…

推动智慧交通建设,边缘计算赋能交通信号灯数据处理与决策能力

随着智慧城市建设的快速发展,智慧交通已成为城市发展的重要组成项目。智慧交通旨在通过大数据、人工智能、物联网等先进技术,实现交通系统的全面感知、智能分析、主动服务和协同管理。边缘计算在交通信号灯物联网应用中展现了交通信号灯数据处理与决策能…

C# 设计倒计时器、串口助手开发

文章目录 1. 实现一个简单的倒计时器开始、暂停2. 串口助手开发 1. 实现一个简单的倒计时器开始、暂停 namespace Timer {public partial class Form1 : Form{int count;//用于定时器计数int time;//存储设定的定时值bool parse false;//控制暂停计时public Form1(){Initiali…

Apollo使用(1):介绍、QuickStart

一、Apollo应用 1、介绍 项目地址:https://github.com/ctripcorp/apollo使用手册:https://github.com/ctripcorp/apollo/wiki Apollo(阿波罗)是携程框架部门研发的分布式配置中心,能够集中化管理应用不同环境、不同集…

Python如何快速定位最慢的代码?优雅了~

编写Python代码时,我们常常会遇到性能瓶颈,这不仅影响程序的执行效率,还可能导致用户体验下降。那么,如何快速定位代码中最慢的部分,成为每个开发者必须掌握的技能。 如何快速定位 Python 代码中的性能瓶颈&#xff1…

优雅单片机之STM32C8T6------蓝牙模块基本设置(2)

0,C8T6系列 1,入门之程序的下载 2,蓝牙模块基本设置(本文) 2,蓝牙模块基本应用 3,蓝牙小车(待定) 一,蓝牙模块基础设置 需要硬件:电脑&#x…

【Linux】进程间通信(2):命名管道

目录 一、命名管道的概念 二、命名管道与匿名管道的区别 1、常规区别 2、读写阻塞的区别 3、存储位置和数据处理的区别 匿名管道 命名管道 三、命名管道的创建与使用 1、在命令行中命名管道的创建与使用 2、在编程中命名管道的创建与使用 2、示例代码 四、命名管道的…

实验2-3-6 计算分段函数[3]

#include<stdio.h> #include<math.h> int main(){double x;scanf("%lf",&x);if (x10)printf("f(%.1f)%.1f",x,1/x);elseprintf("f(%.1f)%.1f",x,x);}

【CSS】css 如何实现固定宽高比

今天和同事讨论这个问题&#xff0c;一时间还想不到了&#xff0c;于是学习了下&#xff0c;就顺便当个记录吧 要在CSS中实现固定宽高比&#xff0c;有两种主要的方法可以选择。一种是使用新的aspect-ratio属性&#xff0c;另一种是利用padding技巧。随着现代浏览器对aspect-ra…

27、美国国家冰雪中心(NSIDC)海冰密集度月数据下载与处理

文章目录 一、前言二、数据下载三、使用Ponply查看数据结构四、代码一、前言 处理美国国家冰雪中心(NSIDC)的海冰密集度月度数据时,坐标转换是一个重要的步骤。NSIDC提供的数据通常采用极地球面坐标系,需要将其转换为常用的地理坐标系(如经纬度)以便进行分析和可视化。 坐…

【数据结构与算法】共享双向链表

共享双向链表 一.共享双向链表的引入二.共享双向链表的原理三.共享双向链表的结构四.共享双向链表的初始化五.共享双向链表插入六.共享链表遍历数据七.共享链表的销毁八.总结 一.共享双向链表的引入 当我们使用双向链表其数据域是固定的类型,如果我需要另外一种类型的话,就需要…

共聚ISC|赛宁网安即将亮相ISC.AI2024第十二届互联网安全大会

随着数字时代的飞速发展&#xff0c;网络安全和人工智能技术的融合已成为推动各行业数智化转型的关键。7月31日至8月1日&#xff0c;备受瞩目的ISC.AI 2024第十二届互联网安全大会将在北京国家会议中心隆重开幕。本届大会将全面聚焦于安全和人工智能两大核心领域&#xff0c;致…

深入探讨Facebook投放菲律宾slots游戏广告的优势

在深入探讨Facebook投放菲律宾游戏广告的优势时&#xff0c;我们不得不提及该平台在本地市场的深厚渗透力与高度互动性。菲律宾作为东南亚地区互联网用户增长最快的国家之一&#xff0c;Facebook不仅是人们日常社交的必备工具&#xff0c;更是信息获取与娱乐消费的重要渠道。因…

Animation Clips

动画剪辑是Unity用来表示对象运动姿态的基础资源&#xff0c;你可以从模型文件中导入动画剪辑&#xff0c;也可以在Unity内部创建简单的动画剪辑。 Import Animation From Model 在导入时只需要确保模型的Animation选项卡中的Import Animation是被激活的&#xff0c;对于没有动…

【Linux】Ubuntu解决Release 文件已经过期问题

​今天在执行update更新软件包时遇到了此问题&#xff1a;E: http://cn.archive.ubuntu.com/ubuntu/dists/jammy-updates/InRelease 的 Release 文件已经过期(已经过期了 247天 21小时 33分 15秒)。该仓库的更新将不会应用&#xff0c;如图 ​ 这个报错之前其实经常遇到&#x…

品酒师眼中的红酒定制:一场不同的味觉盛宴

在红酒的世界里&#xff0c;每一滴酒液都承载着丰富的情感和不同的韵味。当谈到红酒定制时&#xff0c;洒派红酒&#xff08;Bold & Generous&#xff09;无疑为品酒师们带来了一场味觉盛宴。今天&#xff0c;就让我们一起跟随品酒师的目光&#xff0c;探索红酒定制背后的魅…

【Unity渲染】GI

光照探针 光照探针就是在烘焙的时候会布局多个探测点&#xff0c;记录那个地方的光照信息&#xff0c;后面实时渲染动态物体会影响其渲染&#xff0c;动态物体会选择自己周围最近的探针进行影响 反射探针 反射探针就是记录周围环境&#xff0c;计算一个类似天空盒的图片&am…

AIGC-VDM -Video Diffusion Models论文解读

homepage&#xff1a;https://video-diffusion.github.io/ paper:https://arxiv.org/pdf/2204.03458 参考:https://zhuanlan.zhihu.com/p/585009571 视频生成方面的扩散模型 论文Video Diffusion Models精读&#xff0c;笔者会多多更新AIGC相关知识&#xff01;点个关注吧&…

简单高效的在线拾色器工具 - 为您的设计工作提供便利

你是否曾在寻找完美颜色时感到困扰&#xff1f;现在&#xff0c;有了这个简单而强大的在线拾色器工具&#xff0c;选择理想的颜色变得轻而易举&#xff01; 网址&#xff1a; https://potatoh5games.fun/tools/#ColorPickr 这款拾色器工具具有以下特点&#xff1a; 用户友好…

外卖项目day09---微信登录/HttpClient

这里是初学的文章&#xff0c;大家可以去看看 HttpClient初学-CSDN博客 下面是微信登录的流程 微信登录产品原型 UserController代码 RestController RequestMapping("/user/user") Api(tags "C端用户相关接口") Slf4j public class UserController {A…