常哥带你认识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+程序员改简历+面试指导和处理空窗期时间...
你 发表评论:
欢迎- 一周热门
- 最近发表
- 标签列表
-
- oracle位图索引 (63)
- oracle批量插入数据 (62)
- oracle事务隔离级别 (53)
- oracle 空为0 (50)
- oracle主从同步 (55)
- oracle 乐观锁 (51)
- redis 命令 (78)
- php redis (88)
- redis 存储 (66)
- redis 锁 (69)
- 启动 redis (66)
- redis 时间 (56)
- redis 删除 (67)
- redis内存 (57)
- redis并发 (52)
- redis 主从 (69)
- redis 订阅 (51)
- redis 登录 (54)
- redis 面试 (58)
- 阿里 redis (59)
- redis 搭建 (53)
- redis的缓存 (55)
- lua redis (58)
- redis 连接池 (61)
- redis 限流 (51)