百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术教程 > 正文

常哥带你认识NoSQL和Redis的强大

mhr18 2024-11-27 12:07 23 浏览 0 评论

各位朋友,这篇文章是针对Redis快速了解的内容,为了学好Redis在这里首先跟大家聊聊NoSQL相关内容,有了概念和方向后,我们再学习Redis大家会感觉得心应手。

公众号dotNet工控上位机:thinger_swj】

一、NoSQL你必知的那些事儿

1、什么是NoSQL?

NoSQL是Not Only SQL的缩写,意思是“不仅仅是SQL”。也是大家通常所说的非关系型数据库的统称。NoSQL和我们熟悉的关系型数据库的作用一样,都是用来存储数据的仓库。但是在使用方法、存储特点和性能上却大相径庭。

2、为什么要使用NoSQL?

在互联网高速发展的今天,人们对网络需求日益多样化。比如我们使用的QQ、微信、抖音、快手、微博等在线互动、朋友圈、点赞、评论等。不管是在数据访问量和并发量上都是巨大的,这对服务器的数据存储和实时响应提出了更多的挑战。比如以前我们非常熟悉的12306购票网站出来的时候,为什么网站一度瘫痪呢?这个与并发的处理速度是有很大关系的。然而传统的关系型数据库在面对这些海量的数据存储,以及高访问量和高并发读写上面明显不能满足互联网的需求了。按照传统的集群部署增加服务器也难以应对超大规模、高并发、高吞吐量的需求,很多问题已经克服不了了。这时候NoSQL应运而生,从而解决了传统关系型数据库所不能解决的问题。

3、NoSQL解决的问题和特点

【1】扩展方便、数据之间没有直接的关系。

【2】数据模型非常灵活,不用像关系型数据库那样提前需要建立字段类型,随时自定义格式即可存储。

【3】适合大数据量,高性能的存取。

【4】实现了高并发读/写、高可用性。

4、大数据(big data)的定义

我们经常听说大数据,那么如何理解大数据呢?研究机构Gartner公司把大数据定义为高速、巨量且多变的数据。高速是指数据的生成或者变化速度非常快;所谓巨量是指数据的规模很大;多变是指数据类型的范围或数据中所包含的信息范围非常广泛。而NoSQL就是适应大数据时代而产生的。

二、NoSQL与传统关系型数据库对比

我们常见的传统关系型数据库(Traditional Relational DataBase,简称TRDB)有MySQL、Oracle、SQLServer、SQLite、DB2、Access等。我们将从不同方面做对比,让大家更多的了解NoSQL的特点。

1、存储形式:

【1】NoSQL的存储形式非常多样化,如键-值对、图形结构、文档形式、列族形式等。

【2】TRDB的存储都是用关系型数据模型存储,典型的就是列表结构,数据之间有强的依赖关系,用二维表的结构完成数据持久化。

2、查询速度

【1】NoSQL的数据都是在系统的缓存中,不需要专门的SQL层解析,所以查询效率非常高。

【2】TRDB的数据直接存储在硬盘中,查询的时候需要SQL专门的解析,然后进入内存实现查询,效率低。

3、扩展性

【1】NoSQL没有表间关系,可以轻松扩展,采用键-值对存储,数据之间没有耦合性。

【2】TRDB采用关系表存储,而且表间高耦合,想扩展一个表非常难,而且对其他查询影响较大。

4、ACID特性支持

【1】NoSQL一般不支持ACID特性(原子性、一致性、隔离性、持久性)它实现最终一致性。

【2】TRDB支持ACID特性,并且具有严格的数据一致性。

5、SQL语句支持

【1】NoSQL不支持SQL语句,因为没有结构性查询语言。

【2】TRDB支持SQL语句,而且可以支持很复杂的实现。

三、NoSQL数据库的分布式管理机制

为了实现高可用和高扩展、负载均衡等,NoSQL数据库在分布式处理环境下,需要对所有服务器上的数据进行处理。常见的部署方式就是通过主(Master)-从(Salve)模式的分布式方案,这类数据库软件常见的有MongoDB、Redis等。典型的架构如下:

这里的Master或一个Slave都是独立的服务器,我们称为节点(Node)。Master主要承担客户请求处理、给不同的Slave分配数据处理任务,并负责所有Slave的协调一致性等任务。Slave主要负责接收传送到本地的数据、存储和计算过程,并把结果返回给调用者。这点,大家可以先简单了解,后面我们讲解集群的时候,这些还会详细介绍。【公众号dotNet工控上位机:thinger_swj】

四、快速认识Redis的强大

1、Redis的由来

Redis是由意大利Meriza公司的创始人在2009年开发成功的产品,当时是为了解决公司内部的一个实时统计系统的性能,后来经过不断完善,到现在Redis已经非常普及的被使用。

Redis本身是用C语言开发的一款开源的、高性能的键值对存储数据库,才用BSD协议,并且支持多种数据类型:字符串、列表、哈希、有序集合、无序集合等。内置复制、Lua脚本、LRU回收、事务等,以及高性能的持久化功能。

2、Redis的特性

【1】支持多种计算机编程语言。如C#、Java、C、C++、Python、PHP、Lua、Ruby等。

【2】支持多种数据类型。如String、Hash、List、Set、SortedSet等。

【3】读/写速度快、高性能。官方给的数据是11万次/秒读取,8.1万次/秒写入。因为Redis的操作是在内存中进行的,所以速度的惊人的。实际测试也是这个速度。

【4】支持持久化。Redis每隔一段时间可以自动实现备份,在重启的时候会自动加载到内存中。主要有AOF和RDB方式,这个后面我们会详细讲到。

【5】高可用主从复制、分布式集群与负载均衡。Redis的Cluster支持分布式,可以轻松实现分布式集群,Redis Sentinel支持高可用。这个我们都在后面的课程中详细讲解。

3、Redis的使用场景

【1】做缓存。这个是使用最多的场景。Redis的缓存速度和查询速度非常快,使用方便。比如缓存商品信息、购物车等数据。

【2】实现消息队列系统。Redis运行稳定、速度快,可以实现消息订阅发布。Redis还有阻塞队列的命令,使得轻松完成队列,比如秒杀、抢购等。

【3】做实时系统、消息系统。比如实现在线聊天系统。

【4】实现排行榜应用。Redis实现了有序集合。可以轻松对百万级的用户实现排名。

【5】数据过期处理。我们可以设置数据的过期时间,从而实现过期数据的查找和删除等。

【6】做大型社交平台。各种社交APP都可以用Redis做缓存和实时数据处理。

【7】分布式集群架构中的Session分离。采用分布式集群部署,可以满足web应用系统大规模访问量的需求。而实现分布式集群部署,就要解决Session的统一问题。而Redis可以实现Session共享机制。

相关推荐

Redis合集-使用benchmark性能测试

采用开源Redis的redis-benchmark工具进行压测,它是Redis官方的性能测试工具,可以有效地测试Redis服务的性能。本次测试使用Redis官方最新的代码进行编译,详情请参见Redis...

Java简历总被已读不回?面试挂到怀疑人生?这几点你可能真没做好

最近看了几十份简历,发现大部分人不是技术差,而是不会“卖自己”——一、简历死穴:你写的不是经验,是岗位说明书!反面教材:ד使用SpringBoot开发项目”ד负责用户模块功能实现”救命写法:...

redission YYDS(redission官网)

每天分享一个架构知识Redission是一个基于Redis的分布式Java锁框架,它提供了各种锁实现,包括可重入锁、公平锁、读写锁等。使用Redission可以方便地实现分布式锁。red...

从数据库行锁到分布式事务:电商库存防超卖的九重劫难与破局之道

2023年6月18日我们维护的电商平台在零点刚过3秒就遭遇了严重事故。监控大屏显示某爆款手机SKU_IPHONE13_PRO_MAX在库存仅剩500台时,订单系统却产生了1200笔有效订单。事故复盘发...

SpringBoot系列——实战11:接口幂等性的形而上思...

欢迎关注、点赞、收藏。幂等性不仅是一种技术需求,更是数字文明对确定性追求的体现。在充满不确定性的网络世界中,它为我们建立起可依赖的存在秩序,这或许正是技术哲学最深刻的价值所在。幂等性的本质困境在支付系...

如何优化系统架构设计缓解流量压力提升并发性能?Java实战分享

如何优化系统架构设计缓解流量压力提升并发性能?Java实战分享在高流量场景下。首先,我需要回忆一下常见的优化策略,比如负载均衡、缓存、数据库优化、微服务拆分这些。不过,可能还需要考虑用户的具体情况,比...

Java面试题: 项目开发中的有哪些成长?该如何回答

在Java面试中,当被问到“项目中的成长点”时,面试官不仅想了解你的技术能力,更希望看到你的问题解决能力、学习迭代意识以及对项目的深度思考。以下是回答的策略和示例,帮助你清晰、有说服力地展示成长点:一...

互联网大厂后端必看!Spring Boot 如何实现高并发抢券逻辑?

你有没有遇到过这样的情况?在电商大促时,系统上线了抢券活动,结果活动刚一开始,服务器就不堪重负,出现超卖、系统崩溃等问题。又或者用户疯狂点击抢券按钮,最后却被告知无券可抢,体验极差。作为互联网大厂的后...

每日一题 |10W QPS高并发限流方案设计(含真实代码)

面试场景还原面试官:“如果系统要承载10WQPS的高并发流量,你会如何设计限流方案?”你:“(稳住,我要从限流算法到分布式架构全盘分析)…”一、为什么需要限流?核心矛盾:系统资源(CPU/内存/数据...

Java面试题:服务雪崩如何解决?90%人栽了

服务雪崩是指微服务架构中,由于某个服务出现故障,导致故障在服务之间不断传递和扩散,最终造成整个系统崩溃的现象。以下是一些解决服务雪崩问题的常见方法:限流限制请求速率:通过限流算法(如令牌桶算法、漏桶算...

面试题官:高并发经验有吗,并发量多少,如何回复?

一、有实际高并发经验(建议结构)直接量化"在XX项目中,系统日活用户约XX万,核心接口峰值QPS达到XX,TPS处理能力为XX/秒。通过压力测试验证过XX并发线程下的稳定性。"技术方案...

瞬时流量高并发“保命指南”:这样做系统稳如泰山,老板跪求加薪

“系统崩了,用户骂了,年终奖飞了!”——这是多少程序员在瞬时大流量下的真实噩梦?双11秒杀、春运抢票、直播带货……每秒百万请求的冲击,你的代码扛得住吗?2025年了,为什么你的系统一遇高并发就“躺平”...

其实很多Java工程师不是能力不够,是没找到展示自己的正确姿势。

其实很多Java工程师不是能力不够,是没找到展示自己的正确姿势。比如上周有个小伙伴找我,五年经验但简历全是'参与系统设计''优化接口性能'这种空话。我就问他:你做的秒杀...

PHP技能评测(php等级考试)

公司出了一些自我评测的PHP题目,现将题目和答案记录于此,以方便记忆。1.魔术函数有哪些,分别在什么时候调用?__construct(),类的构造函数__destruct(),类的析构函数__cal...

你的简历在HR眼里是青铜还是王者?

你的简历在HR眼里是青铜还是王者?兄弟,简历投了100份没反应?面试总在第三轮被刷?别急着怀疑人生,你可能只是踩了这些"隐形求职雷"。帮3630+程序员改简历+面试指导和处理空窗期时间...

取消回复欢迎 发表评论: