Redis远程字典服务器(1)—— 初识Redis

news2025/1/22 13:08:30

目录

一,关于Redis

二,Redis特性介绍

2.1 In-memory data structures(在内存中存储数据)

2.2 Programmablilty(编程能力)

2.3 Extensibility(扩展能力)

2.4 Persistence(持久化)

2.5 Clustering(集群)

2.6 High availability(高可用)

三,Redis应用场景

3.1 Real-time data store(实时的数据存储)

3.2 session storage(会话存储)

3.3 Streaming & messaging(消息队列)

四,Redis为什么快?

五,在Linux上安装Redis

六,Redis客户端介绍


一,关于Redis

Redis是一个和MySQL一样的“客户端 - 服务器” 结构的程序,Redis客户端和服务器可以在同一个主机上,也可以在不同主机上。

Redis是一个能在内存中存储数据的中间件,可以用作数据库,也可以用作数据缓存,在分布式系统中能大展拳脚

二,Redis特性介绍

2.1 In-memory data structures(在内存中存储数据)

MySQL主要是通过“”的方式来存储和组织数据的,称为“关系型数据库”。

而Redis主要是通过“键值对”的方式来存储组织数据的 --> key是string,value可以是其它的数据结构 --> 称为“非关系型数据库”。

2.2 Programmablilty(编程能力)

针对Redis的操作,我们可以直接通过简单的交互式命令进行操作,也可以通过一些脚本的方式,批量执行一些操作 --> Lua语言,也是编程语言

2.3 Extensibility(扩展能力)

我们可以在Redis原有的功能基础上,再进行扩展,Redis提供了一组API(C,C++,Rust,通过这几个语言编写Redis扩展,本质上就是一个动态链接库)

除了它提供的API,我们可以去自己扩展Redis的功能,比如Redis自身提供了很多的数据结构和命令,通过扩展可以让Redis可以支持更多的数据结构和命令

2.4 Persistence(持久化)

Redis是把数据放在内存上的,这样就可以快速访问而内存上的数据是易失的,进程退出/系统重启等等事件都会使内存没了。
所以Redis会把部分数据存储在硬盘上,内存为主,硬盘为辅,硬盘相当于备份内存数据,如果Redis重启,就会在重启时加载硬盘数据到内存。

2.5 Clustering(集群)

Redis作为一个分布式系统的中间件,能够支持集群是很关键的
一个Redis存储的数据是有限的,内存也是有限的,就可以引入多个服务器,部署多个Redis节点,每个节点存储数据的一部分

2.6 High availability(高可用)

Redis自身也支持主从结构的,从节点相当于主节点的备份,保证系统的可用性(主节点挂了,从节点也能顶上,这个过程是自动的)

三,Redis应用场景

3.1 Real-time data store(实时的数据存储)

  1. 这个就是把Redis当做了数据库,应用与对实时性要求比较高的场景,需要有更低的延迟和更高的吞吐量
  2. 大多数情况下,对于数据存储的考虑首先是“大”,即存储的空间要大,但是仍然有一些场景考虑的是“快”。
  3. 比如“搜索引擎”,广告搜索(商业搜索),对于性能的要求是非常高的,所以搜索引擎中没有用到MySQL这样的数据库,所以就把所有需要检索的数据都存储在内存中,就是使用类似于Redis这样的内存数据库来完成的
  4. 当然,使用这样的内存数据库存储大量的数据,需要不少的硬件资源的,所以一般只有不差钱的大厂才用得起
  5. Redis也可以和MySQL一起使用,遵循二八原则,将热点数据存在Redis中,这种时候Redis存的是全量数据,不能随便丢。也可以让Redis存部分数据,全量数据以mysql为主

3.2 session storage(会话存储)

  1. cookie 是实现用户身份信息的保存,同时也需要session配合(前者只是在浏览器这边存储了一个用户的身份标识,session才是真正存储在服务器上的用户的数据)
  2. 之前的session是直接存储在应用服务器上的,现在变成分布式系统后,引入负载均衡器,用户服务器有多个,用户的请求可能会被随机分发到不同的服务器,所以假设用户第一次请求,负载均衡器分到了1号服务器,生成了会话,但是用户第二次请求时,负载均衡器可能会把数据发到2号服务器,由于2号服务器没有会话,所以可能会重新登录,这样的反复登录会造成大量的资源浪费
  3. 解决:1:想办法让负载均衡器把同一个用户的请求始终打到同一个服务器上     2:把会话数据单独拿出来,放到一台独立的服务器上,每个应用服务器都把会话放到这个服务器上,访问也访问这一个

3.3 Streaming & messaging(消息队列)

  1. 此处的消息队列不是Linux进程间通信的那个,此处的消息队列是一个单独的服务器,只是有了消息队列的功能
  2. 基于这个我们就可以实现一个基于网络版本的生产者消费者模型
  3. 优势:1:解耦合      2,削峰填谷
  4. 业界也有很多知名的消息队列:RabbitMQ,Kafka,RocketMQ等,Redis也是提供了消息队列的功能的,是Redis研发的初心
  5. 但我们几乎不使用Redis作为消息队列使用

四,Redis为什么快?

  1. Redis数据在内存中,就比访问硬盘的数据库,要快很多
  2. Redis的核心功能都是比较简单的逻辑 —— 核心功能基本都是操作内存中的数据结构
  3. 从网络角度上,Redis使用了IO多路复用的方式(epoll,用一个线程管理很多个socket)
  4. Redis使用的是单线程模型(虽然更高版本的Redis引入了多线程,但是只是在网络IO用到了,核心业务逻辑还是单线程),减少了不必要的线程之间的竞争开销,提高效率(多线程不一定能提高效率,前提是CPU密集型的任务,使用多线程可以充分利用CPU多核资源,但是Redis核心任务,主要就是操作内存的数据结构,是比较简单快捷的,不会吃很多CPU资源 —— 没有银弹)
  5. Redis使用C语言开发的,所以快(该结论太勉强,不太认可),比如MySQL也是C语言开发的,凭啥Redis快

五,在Linux上安装Redis

下面展示在Ubuntu环境上安装Redis客户端和服务器,并启动服务器再让客户端连接上服务器

sudo apt install redis

 如果是Centos,就八上面的apt换成yum即可

然后就是修改下配置文件,因为Redis是基于网络的,所以配置文件会默认将Redis的连接IP设为127.0.0.1,我们需要修改成0.0.0.0,表示该服务器可以支持任何其它IP来进行连接

vim /etc/redis/redis.conf

 修改完成后我们直接启动redis服务器(都需要root权限)

sudo service redis-server start

也可以输入这个,查看服务状态,里面有的active,表示正常运行 

service redis-server status

 

 然后就是用客户端连接服务器,直接在命令行输入 redis-cli 即可;进入到客户端以后,输入ping,如果打印PONG,表示客户端正常运行。

然后我们也可以在其它主机上使用特定IP和端口来连接Redis服务器,如下图:

 

六,Redis客户端介绍

Redis也是一个客户端-服务器 结构的程序,MySQL也是这样,redis客户端和服务器可以在同一个主机上,也可以在不同主机上。并且服务器可以给多个客户端提供服务,Redis服务器是本体,负责存储和管理数据

Redis也有很多形态:

  • 自带命令行的客户端:redis-cli  或者也可以redis-cli -h 127.0.0.1 -p 6379
  • 图形化界面:桌面程序,web程序,但是图形化程序依赖与Windows。而以后在实际工作中,用来办公的windows系统,连接到服务器可能会有很多限制,所以不能保证和Linux一样,能100%连上redis服务器(Windows中间可能会经历跳板机,堡垒机,权限校验等)
  • 基于Redis的API自行开发客户端:工作中最主要的形态,非常类似于MySQL的C语言API和JDBC

咱们说Redis快,是相对于MySQL这样的关系型数据库的,但是如果是和内存中的操作变量相比,就没有优势了,甚至更慢。
比如我要存一个键值对,可以用redis来存,也可以直接在内存中搞个hash map来存,但是使用hash map是直接操作内存,使用redis是先通过“网络”,再操作内存的。

所以,是否要使用redis是需要结合实际业务的,引入redis会变慢,但是可以把数据单独存储,服务器重启不会影响到数据内容,假设未来要扩展分布式系统,使用redis是最佳的

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

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

相关文章

食家巷小程序:传统面点与平凉特产的美味盛宴

在美食的世界里,总有一些角落等待着我们去探索,而食家巷小程序就是这样一个为您开启美食宝藏的钥匙。 一、传统面点,传承千年的美味 食家巷小程序为您呈现了种类丰富的传统面点,每一款都蕴含着深厚的历史和文化底蕴。 平凉锅盔&…

x-cmd mod | x jina - 为 jina.ai 打造的命令行工具,提供获取网页内容、生成向量数据等等

目录 简介主要特点子命令例子 简介 Jina.ai 是一家专注于大型语言模型和媒体处理公司。基于 jina.ai 公司的接口,jina 模块主要提供了以下功能: 网页内容获取生成文本向量相关信息检索排序检索 主要特点 通过 jina模块的 Reader 功能,我们…

QT(2.0)

1.常用控件的介绍 1.1 TextEdit QTextEdit表示多行输入框,也是一个富文本&markdown编辑器,并且能在内容超出编辑框范围时自动提供滚动条。 核心属性 属性 说明 markdown 输入框内持有的内容,支持markdown格式,能够自动的…

[Leetcode 215][Medium]-数组中的第K个最大元素-快排/小根堆/堆排序

一、题目描述 原题地址 二、整体思路 (1)快排 对于SELECT K问题,可以通过三路快排解决,快排可以把一个元素放至按升序排序的数组正确的位置,左边为小于该元素的元素集合,右边为大于该元素的元素集合。 三…

朋克养生,现代男人为何对生可乐泡枸杞情有独钟

在当今快节奏、高压力的社会环境中,朋克养生这一独特的养生方式悄然兴起,尤其在年轻男性群体中备受青睐。其中,生可乐泡枸杞这一不乏创意的养生方法,更是成为不少现代男人追求健康与乐趣并存的象征。朋克养生不仅仅是一种外在的行…

lvs的防火墙标记解决轮询调度问题

错误示范 ipvsadm -A -t 192.168.0.200:80 -s rr ipvsadm -a -t 192.168.0.200:80 -r 192.168.0.10:80 -g ipvsadm -a -t 192.168.0.200:80 -r 192.168.0.20:80 -g ipvsadm -A -t 192.168.0.200:443 -s rr ipvsadm -a -t 192.168.0.200:443 -r 192.168.0.10:80 -g ipvsadm -a …

CVE-2024-39877:Apache Airflow 任意代码执行

Apache Airflow 是一个开源平台,用于以编程方式编写、调度和监控工作流。虽然它提供了管理复杂工作流的强大功能,但它也存在安全漏洞。一个值得注意的漏洞 CVE-2024-39877 是 DAG(有向无环图)代码执行漏洞。这允许经过身份验证的 …

游戏ttf字体瘦身脚本

游戏中通常会用到某种特定字体,而某些字体动则10M,对某些游戏(尤其是小游戏)来讲是无法忍受的,此文章主要讲述上个项目中制作的字体裁剪脚本 工具git地址 配置信息(config.json) { // 文本内容(可能为多语言表导出的内容)"txtFile&qu…

常用API(三)

对于常见API的学习,主要学习了关于时间和日期的传统和新增APi 目录 1.Math 2.System 3.Runtime 4.日期和时间 (1)JDK8前传统时间API [1] Date [2] SimpledateFormat [3]Calendar (2)JDK8后新增时间API [1]代替…

JeecgBoot低代码平台简单记录

BasicModal弹窗 Usage 由于弹窗内代码一般作为单文件组件存在,也推荐这样做,所以示例都为单文件组件形式 注意v-bind"$attrs"记得写,用于将弹窗组件的attribute传入BasicModal组件 attribute:是属性的意思,…

嵌入式学习之线程和同步互斥机制

一. 线程的概念 进程的上下文切换: a.上下文:运行一个进程所需要的所有资源。 b.上下文切换:替换原有内容,从访问进程A的所有资源切换到访问进程B的所有资源,是一个耗时操作。 c.为了提高系统性能,引入了一…

HCIP | 实验一

实验内容 配置 1.合理规划IP地址,启用OSPF单区域 R1 R2 R3 R4 R5 R6 2.R1-R2之间启用PPP的pap单向认证 R1 R2 3.R2-R3之间启用PPP的chap双向认证 R2 R3 4.R3-R5-R6之间使用MGRE,R3为hub端,R5,R6为spoke端,要求MGRE…

DS1302实时时钟(51单片机)

一、DS1302时钟 1.DS1302时钟介绍 2.芯片使用 使用芯片时首先要通过数据手册知道芯片功能,根据芯片功能应用。 3.实现DS1302功能 通过对配置寄存器使用DS1302的读写功能 二、实现DS1302读写 1.模块化编程框架 首先对DS1302端口重新定义(换端口名字…

汽车电子推拉力测试机测试流程的详细步骤

在现代汽车技术迅猛发展的今天,汽车电子产品的可靠性已成为确保车辆性能和乘客安全的关键因素。标准下的键合线剪切试验,作为评估这些产品中关键连接点强度的一项测试,扮演着至关重要的角色。本文旨在深入探讨这一测试的重要性、实施流程及其…

Java学习Day20

Vue学习 nodejs的安装与环境配置 1.直接去官网下载合适版本的nodejs( https://nodejs.org/zh-cn/download/prebuilt-installer) 2.解压下载的安装包,将文件路径配置到系统变量的path中,然后确认后退出。可以使用终端来查看安装的nodejs版本。使用winR…

智能合约的未来:解析Web3在智能合约领域的创新

随着区块链技术的不断发展,智能合约已成为Web3生态系统中的核心组成部分。智能合约通过在区块链上自动执行合约条款,推动了去中心化应用(DApp)的广泛应用。它们的核心优势在于去中心化、透明和不可篡改,这使得合同执行…

uniapp切换同一个子组件时,钩子函数只进了一次

给子组件添加不同的 “key” 值,当 key 值改变时,Vue 会认为这是一个不同的组件,并重新创建它 props: ["L1Id"],// 方式1: 使用keycomputed: {// 切换子组件时,发现created、mounted等钩子函数只会进一次,或者用 keykey(){this.ref…

RAG私域问答场景超级详细方案(第一期方案)[1]:工业级别构建私域问答(知识处理、知识召回排序、搜索问答模块)

RAG私域问答场景整体夏详细方案(第一期方案):工业级别构建私域问答(知识处理、知识召回排序、搜索问答模块) 大模型性能的跳阶式增长给文本摘要、信息检索、信息抽取、语义问答等自然语言处理任务带来了卓越的性能提升。同时,LangChain 作为一种基于 LLM 的框架,能够快速…

【autoware】安装ros2 密匙gpg报错,443连接失败

443连接问题解决方法: 访问该网站 https://ping.chinaz.com 输入raw.githubusercontent.com可以得到解析出来的IP sudo vim /etc/hosts

Unity射击游戏开发教程:(31)制造一定追踪行为的敌人

在本文中,我们将介绍如何在两种敌人行为之间切换。本文是前两篇文章的延续,分别介绍了敌人躲避玩家射击以及敌人不断旋转并向玩家射击的情况。我只是介绍如何在这两种行为之间进行转换。 这种新的敌人行为的目标: 当不开火时,敌人可以躲避玩家的射击。射击时,敌人无法躲避…