Redis的特性以及使用场景

分布式发展历程参考 陈佬 http://t.csdnimg.cn/yYtWK 

介绍redis

Redis(Remote Dictionary Server是一个基于客户端-服务器架构的在内存中存储数据中间件,属于NoSQL的一种。它可以用作数据库、缓存/会话存储以及消息队列

作为一种内存数据库,Redis将数据存储在内存中,因此能够实现非常快速的读写操作。与磁盘存储相比,内存存储能够大幅提升数据的访问速度。这使得Redis成为一个优秀的缓存系统,能够将频繁访问的数据存储在内存中,从而提高读取性能。数据库服务器中的冷热分离(二八原则,对于经常被查询的数据,可以将其存储在Redis中,利用Redis快速的读取和写入能力,以提升数据的访问速度。)就可用redis实现

此外,Redis还提供了丰富的数据结构支持,包括字符串、哈希表、列表、集合和有序集合等,使得它不仅可以简单地存储键值对,还可以处理复杂的数据结构,满足各种不同的需求。

在分布式架构中,Redis也具备主从复制、Sentinel机制和Cluster集群等特性,以确保高可用性和扩展性。


 * 介绍NoSQL

MySQL和NoSQL是两种不同类型的数据库系统,它们各自具有一些特点和适用场景。

  1. MySQL

    • 关系型数据库管理系统(RDBMS),采用结构化数据表来存储数据,支持 SQL 查询语言。
    • 适用于需要复杂事务处理、强一致性和丰富的查询功能的应用场景。
    • 支持ACID(原子性、一致性、隔离性、持久性)事务特性,确保数据的完整性和一致性。
    • 具有成熟的数据建模能力,支持复杂的关联查询、多表连接等操作。
    • 适用于需要严格数据一致性和复杂数据分析的企业级应用。
  2. NoSQL

    • 非关系型数据库系统,使用灵活的数据模型,可以存储半结构化或非结构化数据。
    • 适用于大规模分布式系统、高并发读写、数据量巨大的场景。
    • 分为多种类型,包括键值存储、文档型数据库、列存储数据库和图形数据库等,每种类型的NoSQL数据库都有自己的优势。
    • 通常以牺牲一部分ACID特性为代价,追求高可用性、横向扩展和灵活的数据模型。
    • 更适合于需要高性能、大容量存储和灵活的数据模型的应用,例如日志记录、实时分析、内容管理等场景。

在选择数据库系统时,需要根据具体的应用需求来进行权衡。如果应用需要复杂的事务处理和强一致性,以及复杂的查询需求,那么MySQL等关系型数据库可能是更好的选择。而对于需要高性能、大规模存储和分布式部署的场景,NoSQL数据库可能更为合适。

此外,还有一种趋势是将关系型数据库和NoSQL数据库结合使用,即所谓的“多模型数据库”,以充分发挥各自的优势,满足不同的业务需求。

redis特点

官网https://redis.io/

以下是Redis的一些主要特点:

  1. 内存存储:Redis将数据存储在内存中,因此读写操作非常快速(以实现高速的读写操作(还引入了IO多路复用,一个线程管理多个socket)。这使得Redis能够实现非常低延迟和高吞吐量的数据访问此外,Redis也支持将数据异步地持久化到磁盘上,以便在重启后能够恢复数据。
  2. 键值存储:Redis是一种键值存储系统,每个键都关联着一个值,这个值可以是字符串、哈希、列表、集合等多种数据结构。通过键快速访问和操作对应的值
  3. 数据结构支持:除了基本的字符串键值对之外,Redis还支持丰富的数据结构,如列表、集合、有序集合、哈希表等,这使得Redis可以应对各种不同的需求。
  4. 可编程性:可直接通过简单的交互式命令进行操作,也可通过脚本的方式,批量执行操作
  5. 可扩展性:Redis提供了一组API,在原有的功能上进行扩展(以支持更多的数据结构,命令),通过几个语言编写Redis扩展,本质上是一个动态链接库
  6. 持久化与备份:除了将数据存储在内存中,Redis还支持将数据持久化到硬盘上,以防止数据丢失
  7. 分布式(支持集群):Redis Cluster可以让多个Redis实例组成集群,从而提供了分布式的能力。
  8. 高可用性:Redis提供了主从复制(Master-Slave Replication)和哨兵(Sentinel)机制来确保高可用性和故障转移。以提供数据的高可用性和容错能力。通过配置主从复制和哨兵节点,Redis可以实现自动故障恢复和故障转移

由于其快速、灵活和丰富的功能,Redis被广泛应用于缓存、会话存储、消息队列、实时排行榜、发布/订阅系统等方面。

redis使用场景 

 

  1. 实时数据存储:Redis的快速读写能力和多功能的数据结构使其非常适合用于实时数据存储。例如,在在线游戏中,可以使用Redis存储玩家的实时位置、状态等数据;在金融交易系统中,可以使用Redis存储实时的市场行情数据;

  2. 缓存和会话存储:Redis作为缓存的应用非常广泛。它可以存储经常被查询的数据,如数据库查询结果、计算结果、API调用的响应等,从而大幅提高系统的性能和响应速度。此外,Redis还被广泛用作会话存储,用于存储用户登录状态、购物车信息等会话相关的数据。

  3. 消息队列(生产者-消费者模型,优势:解耦合;削峰填谷):Redis的流数据类型支持高速数据引入和消息传递,因此在消息队列、事件溯源等场景中有着重要的应用。它可以用于实现发布/订阅模式,处理实时的消息传递和事件通知,也可以用于构建简单的流媒体系统,处理实时数据的输入和输出。

    不能使用Redis存储大规模数据

 

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

【Pytorch和深度学习】栏目导读

一、栏目说明 本栏目《pytorch实践》是为初学者入门深度学习准备的。本文是该栏目的导读部分,因为计划本栏目在明年完成,因此,导读部分,即本文也在持续更新中。 本栏目设计目标是将深度学习全面用pytorch实践一遍,由浅…

原型模式 rust和java的实现

文章目录 原型模式介绍优点缺点使用场景 实现java 实现rust 实现 rust代码仓库 原型模式 原型模式(Prototype Pattern)是用于创建重复的对象,同时又能保证性能。 这种模式是实现了一个原型接口,该接口用于创建当前对象的克隆。当…

mysql主从复制-使用心得

文章目录 前言环境配置主库从库 STATEMENTbinloggtidlog-errorDistSQL总结 前言 mysql 主从复制使用感受,遇到一些问题的整理,也总结了一些排查问题技巧。 环境 mysql5.7 配置 附:千万级数据快速插入配置可以参考:mysql千万数…

数据分析面试题1

1.右表为一组数据,尝试进行简单分析,并给出结论(使用公式和图表辅助) ①理解数据 userid:用户id神兽印记消耗数量 ②数据清洗 冻结首行,将列标题的英文字段转换成汉字字段检查是否有重复项:…

STM32F407: CMSIS-DSP库的移植(基于源码)

上一篇:STM32F407: CMSIS-DSP库的移植(基于库文件)-CSDN博客 1. 拷贝源码 仿照官方源码目录,新建一个source目录:\Drivers\CMSIS\DSP\Source 将所有源文件拷贝过来,如下: 然后在每个目录下新建一个总的c文件&#x…

CSS花边001:无衬线字体和有衬线字体

网站中我们看到过很多字体,样子各有千秋。通常针对结构,区分为有衬字体(serif) 和无衬字体(sans-serif)。今天我们聊一下这个话题。 什么是有衬字体,什么是无衬字体? 衬线字体&…

sqli-labs关卡16(基于post提交的双引号加括号闭合的布尔盲注)通关思路

文章目录 前言一、回顾上一关知识点二、靶场第十六关通关思路1、判断注入点2、猜数据库长度3、猜数据库名字4、猜表名长度5、猜表名名字6、猜列名长度7、猜列名名字8、猜数据长度9、猜数据名字 总结 前言 此文章只用于学习和反思巩固sql注入知识,禁止用于做非法攻击…

已解决:java.net.BindException: 地址已在使用

解决zookeeper报错:java.net.BindException: 地址已在使用,是因为端口被占用。显示Starting zookeeper ... STARTED,jps没有QuorumPeerMain进程。 问题截图: 看似Starting zookeeper ... STARTED,实则集群并没有启动…

逻辑回归-癌症病预测与不均衡样本评估

1.注册相关库(在命令行输入) pip install scikit-learn pip install pandas pip install numpy 2.导入相关库 import pandas as pd import numpy as np from sklearn.metrics import classification_report from sklearn.model_selection import train_test_split…

【每日一题】—— B. Deja Vu(Codeforces Round 907 (Div. 2))(暴力枚举、队列)

🌏博客主页:PH_modest的博客主页 🚩当前专栏:每日一题 💌其他专栏: 🔴 每日反刍 🟡 C跬步积累 🟢 C语言跬步积累 🌈座右铭:广积粮,缓称…

“苹果定律”失效,2023是VR的劫点还是拐点?

因为Pico裁员的事情,VR行业又被讨论了。 Pico于2021年9月被字节跳动收购,当时是出货量排名全球第三的VR 头显生产商。 此前曾有国际机构预测,2023年随着Meta和Pico的硬件更新,苹果Vision Pro的推出,三星电子重新回归VR…

黑马程序员微服务Docker实用篇

Docker实用篇 0.学习目标 1.初识Docker 1.1.什么是Docker 微服务虽然具备各种各样的优势,但服务的拆分通用给部署带来了很大的麻烦。 分布式系统中,依赖的组件非常多,不同组件之间部署时往往会产生一些冲突。在数百上千台服务中重复部署…

初探地理编码(2023.11.12)

地理编码相识 2023.11.12 引言1、地理编码简介2、地理编码API和服务(解决方案供应商 / 厂商)2.1 高德2.2 百度2.3 超图2.4 天地图2.5 ArcGIS2.6 MapBox2.7 Cesium2.8 MapLocation 3、python实例3.1 pip安装依赖库(python 3.6)3.2 …

git分支与tag标签的介绍与使用)

git分支与tag标签的介绍与使用 一.什么是分支与标签1.2.开发环境分层 二git分支介绍2.1分支操作2.2.IDEA中操作分支 三、Git标签的讲解3.1.GitBashHere操作标签3.2. IDEA中操作标签 一.什么是分支与标签 分支(Branches): 功能开发&#xff…

Jenkins简介及Docker Compose部署

Jenkins是一个开源的自动化服务器,用于自动化构建、测试和部署软件项目。它提供了丰富的插件生态系统,支持各种编程语言和工具,使得软件开发流程更加高效和可靠。在本文中,我们将介绍Jenkins的基本概念,并展示如何使用…

PyCharm 安装库时显示连接超时

在setting->python Interpreter 中用“” 安装库时,出现一个弹窗,提示信息如下: Error updating package list: Connect timed out 通过查阅资料,发现是镜像源的问题,具体的解决方案如下: 1. 更新一下…

初始MySQL(四)(查询加强练习,多表查询(未完))

目录 查询加强 where加强 order by加强 group by 分页查询 总结 多表查询(重点) 笛卡尔集及其过滤 自连接 子查询 #先创建三张表 #第一张表 CREATE TABLE dept(deptno MEDIUMINT NOT NULL DEFAULT 0,dname VARCHAR(20) NOT NULL DEFAULT ,loc VARCHAR(13) NOT NULL D…

v-bind和v-model

目录 前言 v-bind 作用 语法格式 编译原理 简写 v-model 作用 使用方法 v-bind和v-model的区别和联系 前言 本文我们来了解一下模板语法之指令语法中的v-bind和v-model v-bind 作用 v-bind可以让html标签的某个属性的值产生动态的效果 语法格式 <html标签 v-bin…

菜单栏管理软件 Bartender 3 mac中文版功能介绍

​Bartender 3 mac是一款菜单栏管理软件&#xff0c;该软件可以将指定的程序图标隐藏起来&#xff0c;需要时呼出即可。 Bartender 3 mac功能介绍 Bartender 3完全支持macOS Sierra和High Sierra。 更新了macOS High Sierra的用户界面 酒吧现在显示在菜单栏中&#xff0c;使其…

Anolis 8.6 安装 Drawio

Anolis 8.6 安装 Drawio 22.1.0 一.RPM版&#xff08;不建议&#xff09;二.WAR 包部署 一.RPM版&#xff08;不建议&#xff09; Draw RPM 包下载链接 RPM 包直接基于Linux图形化能力部署&#xff0c;服务器类型的Linux系统启动RPM包安装的Draw可能比较复杂 系统版本 ## 1.…