【Redis 系列】redis 学习一,数据库的演进及 Nosql 的初步认知

本文涉及的产品
RDS MySQL DuckDB 分析主实例,集群系列 4核8GB
PolarDB Agent Express,2核4GB
RDS MySQL DuckDB 分析主实例,基础系列 4核8GB
简介: 【Redis 系列】redis 学习一,数据库的演进及 Nosql 的初步认知

【Redis 系列】redis 学习一,数据库的演进及 Nosql 的初步认知

Nosql

为什么要用 Nosql ?

咱们一起来看看数据库的发展过程

1、单机的 MYSQL 时代

应用访问数据库是 应用 – DAL 数据库访问层 – DB 数据库

image.png

在单机的 MYSQL 时代,数据都不会太大,而且网页也是静态网页,一般网站的访问量也小,因此单数据库就完全够用了

上面这种网站,瓶颈就会很明显:

  • 数据量变得大了,一个机器放不下如何处理
  • 数据的索引 (B+ Tree),一个机器的内存放不下了如何处理
  • 读写的访问量,一个服务器承受不了了如何处理

随着历史进程的演进,上面这种网站必然会面临如上问题,就必须要解决

2、Memecache + MYSQL + 垂直拆分

为了解决上面的问题,一个机器处理不过来,我们就放多个机器,但是如何保证数据的一致性呢?

因此就想到了读写分离,专门指定一个数据库用于写数据,其他数据库用于读取数据,并且其他的数据库会同步用于写数据的 MYSQL 中的数据

image.png

渐渐的发现每次请求,都需要去操作数据库,这样耗时耗力,需要改变

因此在访问数据库之前,加入了缓存服务器 Memcache,第一次读取数据库,第二次读取的时候在数据库不改变的情况下,读取 Memcache 中的数据,减小数据库的压力

image.png

这一块发展历程是这样的:

优化数据库的结构和索引 – 文件缓存(IO) – 缓存服务器 Memcache

3、分库分表 + 水平拆分 + MYSQL 集群

随着技术发展,业务也跟着飞越发展,也就带来了更多的问题

最开始我们使用的 MYSQL 使用的引擎的是 MyISAM,他是表锁,十分影响效率,当在高并发的情况下,问题尤为明显

后面就有了 MYSQL 的 InnoDB 引擎,他是行锁,随着业务的不停增长,就有了 MYSQL 集群

image.png

使用集群的方式,每一个集群存储一部分数据,若数据量仍然上升,那么继续增加集群部署

4、现在

由于现代的数据量真的非常大了,大数据时代了,MYSQL 关系型数据库就不够用了,现在数据量多,变化快,以前使用 MYSQL ,设计的时候,就得把所有字段,可能用到的字段,全部想清楚,设计明白,对于现在瞬息万变的时代,这就很难了

现在就会期望,例如存储文件的有文件服务器,存储图片的有图片服务器,有专门的数据库来存这些数据,那么 MYSQL 的压力就会小很多

现在 的互联网项目简单来看是这个样子的

image.png

对于这样的互联网项目,就非常需要 Nosql 了,Nosql 能处理上述出现的问题

Nosql 是什么?

Nosql

Not only sql , 不仅仅是 sql

泛指非关系型数据库,随着 web2.0 互联网的诞生,传统的关系型数据库很难对付 web2.0 时代了

例如现在互联网用户需要存储个人信息,定位信息,社交网络等等数据,Nosql 对于这些数据存储不需要用一个固定的格式就可以存储,而且很轻易就可以横向扩展,例如Map ,使用键值对来控制就很 nice 了

Nosql 的特点

  • 方便扩展,因为数据之间没有关系,很容易扩展
  • 高性能,例如 redis 1 秒能写 8 万次,能读 11 万次,且 Nosql 的存储是记录级别的,是一种细粒度的缓存,因此性能高
  • 数据类型多样,不需要事先设计数据库

咱们来对比一下传统型的关系型数据库(RDBMS)和 Nosql

RDBMS

  • 结构化组织
  • sql 语句
  • 数据和关系都存在单独的表中
  • 数据操作,数据定义语言
  • 严格的一致性
  • 事务处理 等等

Nosql

  • 不仅仅是数据
  • 没有固定的查询语言
  • 键值对存储,列存储,文件存储,图形数据库 例如社交关系等等
  • 最终一致性
  • CAP 定理和 BASE 原理
  • 高可用,高性能,高可扩展

顺便一起分享一下 3 V 和 3 高分别是什么:

3 V,主要是用来描述问题的:

  • 海量数据 volume
  • 多样性 variety
  • 实时性 velocity

3 高,主要是用来描述对程序的要求

  • 高并发
  • 高性能
  • 高可扩展

Nosql 的四大分类

KV 键值对:

  • Redis

C 编写的,单进程的 Nosql, 阿里,腾讯,百度,字节等公司都在用使用

文档型数据库:

  • Mongdb

Mongdb 是一个基于分布式文件存储的数据库,C++ 编写的,主要用来处理大量的文档

Mongdb 还是一个介于关系型数据库和非关系型数据库中间的产品,他是非关系型数据库中功能最丰富的,最像关系型数据库的非关系型数据库

列存储型数据库:

  • HBase
  • 分布式文件系统

图关系型数据库:

  • Neo4j
  • InfoGrid

图关系型数据库不是存储图形,而是存放关系,例如社交关系网络

image.png

咱们来对比一下上述四种分类:

image.png

图片来源于网络,这张图片已经很清晰的描述了KV 键值对,文档型数据库,列存储数据库,图形数据库的案例,数据模型,优缺点,现在对于 Nosql 会有了一个大体的认知了吧

欢迎点赞,关注,收藏

朋友们,你的支持和鼓励,是我坚持分享,提高质量的动力

image.png

好了,本次就到这里

技术是开放的,我们的心态,更应是开放的。拥抱变化,向阳而生,努力向前行。

我是阿兵云原生,欢迎点赞关注收藏,下次见~


相关文章
|
9月前
|
存储 NoSQL Redis
阿里云高性能数据库Tair(兼容 Redis)收费价格,稳定可靠成本低
阿里云高性能云数据库Tair兼容Redis,提供Redis开源版和Tair企业版,支持多种存储介质与灵活扩展,适用于高并发场景。Tair具备亚毫秒级稳定延迟,保障业务连续性。价格方面,Redis开源版年费从72元起,Tair企业版年费从1224元起,具体费用根据配置不同有所变化。
|
存储 NoSQL 数据库
Redis 逻辑数据库与集群模式详解
Redis 是高性能内存键值数据库,广泛用于缓存与实时数据处理。本文深入解析 Redis 逻辑数据库与集群模式:逻辑数据库提供16个独立存储空间,适合小规模隔离;集群模式通过分布式架构支持高并发和大数据量,但仅支持 database 0。文章对比两者特性,讲解配置与实践注意事项,并探讨持久化及性能优化策略,助你根据需求选择最佳方案。
1127 5
|
8月前
|
人工智能 运维 NoSQL
云栖大会|AI浪潮下的NoSQL演进:下一代数据库的破局之道
AI浪潮下的NoSQL演进:下一代数据库的破局之道
|
8月前
|
NoSQL 算法 Redis
【Docker】(3)学习Docker中 镜像与容器数据卷、映射关系!手把手带你安装 MySql主从同步 和 Redis三主三从集群!并且进行主从切换与扩容操作,还有分析 哈希分区 等知识点!
Union文件系统(UnionFS)是一种**分层、轻量级并且高性能的文件系统**,它支持对文件系统的修改作为一次提交来一层层的叠加,同时可以将不同目录挂载到同一个虚拟文件系统下(unite several directories into a single virtual filesystem) Union 文件系统是 Docker 镜像的基础。 镜像可以通过分层来进行继承,基于基础镜像(没有父镜像),可以制作各种具体的应用镜像。
882 6
|
存储 NoSQL 搜索推荐
NoSQL数据库分类概览
以上就是我们的NoSQL数据库奇幻之旅。每一种NoSQL数据库都有自己独特的魅力和专长,择选合适的数据库,就像在魔法世界中挑选最适合自己的魔杖,使你的数据管理变得更加高效和神奇。在当今数据驱动的时代,懂得这些数据库的秘密,就掌握了处理各种数据挑战的关键。
569 61
|
缓存 NoSQL Redis
Redis原理—2.单机数据库的实现
本文概述了Redis数据库的核心结构和操作机制。
Redis原理—2.单机数据库的实现
|
NoSQL Java Redis
Redis Pipeline介绍 ---- 提高操作Redis数据库的执行效率。
Redis Pipeline是提高Redis执行效率的重要技术,通过批量发送命令,显著减少了网络往返次数,提高了系统的吞吐量和性能。在实际应用中,合理使用Pipeline可以有效优化Redis的性能,特别是在需要批量操作的场景下。本文通过Python和Java的示例代码展示了如何实现和使用Redis Pipeline,为开发者提供了具体的操作指南。
668 16
|
消息中间件 缓存 NoSQL
缓存与数据库的一致性方案,Redis与Mysql一致性方案,大厂P8的终极方案(图解+秒懂+史上最全)
缓存与数据库的一致性方案,Redis与Mysql一致性方案,大厂P8的终极方案(图解+秒懂+史上最全)
|
存储 缓存 NoSQL
云端问道21期方案教学-应对高并发,利用云数据库 Tair(兼容 Redis®*)缓存实现极速响应
云端问道21期方案教学-应对高并发,利用云数据库 Tair(兼容 Redis®*)缓存实现极速响应
469 1
|
存储 NoSQL Redis
NoSQL-Redis入门(二)
Redis要点: 1.关键字(keys)用于标识一段数据的字符串 2.值(values)是一段任意的字节序列,Redis不会关注他们实质是什么 3.Redis展示了5种专门的数据结构 4.上面几点使得Redis快速而且容易使用,但Redis不适用于所有的应用场景 1.Redis的数据结构 每种数据结构的要点包括: 1.是什么? 2.包含的有效方法 3.使用这些数据结构能处理哪些类型的特性和数据 1.1 字符串(String) 在Redis里,字符串是最基本的数据结构。
1157 0