我为什么放弃MySQL?最终选择了MongoDB
mhr18 2024-12-07 21:34 21 浏览 0 评论
我为什么放弃MySQL?最终选择了MongoDB
最近有个项目的功能模块,为了处理方便,需要操作集合类型的数据以及其他原因。考虑再三最终决定放弃使用MySQL,而选择MongoDB。
两个数据库,大家应该都不陌生。他们最大的区别就是MySQL为关系型数据库,而MongoDB为非关系型数据库。常见的关系型数据库有:MySQL、Oracle、DB2、SQL Server、Postgre SQL等,非关系型数据库有MongoDB、Redis、Memcached、HBse等等。
1、关系型数据库? 非关系型数据库?
关系型数据库可以理解为依赖一个模型来创建的数据库,比如我们使用的MySQL中的表是由横列和纵列组成的一个二维表格。关系型数据库可以通过关系模型使多个表的数据关联起来,比如我们平时说的 一对一、一对多、多对一。由于是建立在数据模型的基础上,所以我们可以通过SQL语句很方便的在多个表之间做复杂的查询操作。关系型数据库相对安全,因为直接存储在硬盘中所以突然的宕机、停电等意外不会导致数据丢失。MySQL的存储方式是由自身的引擎决定的,常用的引擎有Innodb和MyISAM。他们主要的区别就是MyISAM 不支持事务,强调的是性能,执行速度比Innodb要快,Innodb提供支持事务等高级数据库功能。
非关系型数据库即我们常说的NoSQL数据库,部署起来都比较简单,没有关系型数据库那么复杂。Mongo的存储方式为虚拟内存+持久化存储,Mongo将数据写入内存中,再由虚拟内存管理器将其持久化到硬盘中,因此写操作会比关系型数据库快很多。NOSQL的存储格式是key-value形式,可以像关系型数据库那样存储基础数据类型的数据,也可以存储集合、对象等等。NoSQL虽然性能比较高,但是并不支持事物,也不能进行联表查询,一般用于较大规模数据的存储。
2、他们的优点、缺点有哪些
关系型数据库发展了很长一段时间,拥有非常成熟的体系。所占份额也在逐渐增加。而且支持事物的操作,保证数据的一致性,可以通过SQL语句完成复杂的操作。但是使用过程中当数据量到达一定程度时,关系型数据库的效率会有明显的下降。一个复杂的查询操作,一系列的组合索引都会消耗非常多的内存空间,此时我们需要对数据库进行读写分离操作,或者将数据库结构进行拆分(水平拆分、垂直拆分)将请求压力分担在不同的库中。
垂直拆分是指将一张表拆分成多个表,表之间通过主键进行关联。
水平拆分是按照某种规则拆分成多个表,比如通过用户角色进行拆分
读写分离:所谓读写分离就是讲读操作(查询数据)和写操作(插入&更新)指向不同的数据库节点,他们中间通过某种机制实现数据的同步,如binlog。实际的应用中大部分压力还是来自读操作,所以主要是一主多从的架构。
非关系型数据库发展的这几年,深受人们的喜爱。免费开源、成本低、部署简单、非结构化存储等等明显的优势。而且它对海量数据处理能力非常强,内存级数据库,查询速度也非常快。存储的数据格式比较丰富,易于扩展,虽然不能使用sql进行复杂的查询,但是MongoDB支持JavaScript,所以可以通过js脚本进行复杂的数据库管理操作。关于NoSQL的缺点个人感觉目前就是不支持事物了吧,其他方面那都不是事儿。
3、什么时候用mongo
Mongo是用c++编写的,支持多种语言如:Java、Python、Ruby、PHP、C++、C# 等,有时候针对不同的业务需求,选择Mongo能够避免浪费很多不必要的资源
日志系统
系统运行过程中产生的日志信息,一般种类较多、范围较大、内容也比较杂乱。通过MongoDB可以将这些杂乱的日志进行收集管理。不仅方便了管理,查找或者导出也会变得非常容易
地理位置存储
MongoDB支持地理位置、二维空间索引,可以存储经纬度,因此可以很快的计算出两点之间的距离,等位置信息。如查询附近的人、或者订餐系统、配送系统等
数据规模增长很快
前面提到过关系型数据库数据量过大时,需要进行分库分表,这样真正操作起来可能会比较麻烦。如果选择mongo进行分库分表操作时,就会变得很简单。
保证高可用的环境
Mongo本身就拥有高可用及分区的解决方案,设置主从服务器非常方便,除此之外Mongo还可以快速并且安全的实现故障节点的转移。
文件存储需求
GridFS是MongoDB规范,用于存储和检索图片、音频、视频等大文件。GridFS虽然是文件存储的一种方式,可以存储超过16M的文件。但是它本身又是存储在MongoDB集合中的
其他场景
如游戏开发中我们可以通过MongoDB存储用户信息、装备、积分等,除此之外物流系统、社交系统、甚至物联网系统,Mongo都能提供完美的数据存储服务。
4.MySQL、MongoDB简单的性能测试
关于两个数据的性能,最有力的的说话还是通过实践来进行测试,网上看到一组测试数据,分享给大家。
测试环境:Windows 10、内存8G、CPU i5 3.30GHZ。均无索引
测试语言:Python
链接工具:pymysql、pymongo
MySQL && Mongo 测试数据统计
提交次数 | 单次提交个数 | MySQL运行时间(s) | Mongo运行时间(s) | 数据量 | |
1 | 1000 | 10000 | 3912 | 1622.02 | 0 |
2 | 100 | 100 | 30 | 1.61 | 1000万 |
3 | 100 | 100 | 5.77 | 1.60 | 0 |
4 | 10 | 25 | 2.35 | 1.56 | 0 |
5 | 10 | 25 | 7.42 | 1.60 | 1000万 |
6 | 10000 | 1 | 298.07 | 5.29 | 0 |
7 | 10000 | 1 | 496.18 | 5.29 | 1000万 |
- 上一篇:一次线上事故,我顿悟了MongoDB的精髓
- 下一篇:JWT授权认证详细解读
相关推荐
- Linux下乱码的文件名修改或删除(linux文件名乱码如何处理)
-
查看文件名#lstouch1?.txt#ll-itotal1469445217956913-rw-r--r--1oracleoinstall0Jan18...
- 「论文写作-解决方案」数据库TDE加密
-
数据是应用的核心。对于绝大多数应用,存储数据的数据库是系统日常管理的重中之重。数据库安全背景根据verizon2014年的统计数据,96%数据攻击行为是针对数据库进行的。数据库已经成为外部入侵与内部渗...
- 数据库监控工具应具备的关键特性(数据库监控哪些指标)
-
数据库性能的好坏直接影响到应用程序的运行和企业的收益。缓慢的数据库可能导致应用程序崩溃,进而影响企业利润。因此,您需要一种不仅能够应对问题,还能主动预防问题的监控策略。优秀的数据库监控工具通过实时洞察...
- Hive的安装(Hive的安装过程通常包括哪些主要步骤?)
-
Hive的运行是基于Hadoop集群上的,所以Hive的安装优先得先搭建好Hadoop集群,可以参考:hadoop详细安装步骤:https://www.oraclejsq.com/hdpjc/060...
- 香港DM德馬大中華非遺共創集團/ 甲骨文“意”YI字写法和解释
-
甲骨文香港DM德馬大中華非遺共創集團20240704期甲骨文“意”YI字写法和解释Oracleboneinscription“Meaning”yiwritingandinterpreta...
- 香港DM德马数字甲骨文集团20240816期 甲骨文“若”RE字写法和解释
-
香港DM德马数字甲骨文集团20240816期甲骨文“若”RE字写法和解释Oracle-boneinscription“If”REwritingandinterpretation“若”字像一...
- 香港DM德马数字甲骨文集团20240812期 甲骨文“萨”SA字写法和解释
-
香港DM德马数字甲骨文集团20240812期甲骨文“萨”SA字写法和解释Oracleboneinscription“SA”sawritingandinterpretation“萨”会意字...
- 香港DM德馬景泰藍文科集團20250605期《無堅不摧》DMSIXSEVEN
-
香港DM德馬景泰藍文科集團20250605期《無堅不摧》DMSIXSEVEN/LINJINGDE/1973主編供圖:香港DM德馬數字甲骨文集團Hongkong-basedDMDelma...
- VirtualBox 7.0.16 权限提升漏洞(virtualbox uuid)
-
VirtualBox7.0.16权限提升漏洞,直接上代码:#ExploitTitle:VirtualBox7.0.16-LocalPrivilegeEscalation#Dat...
- 有多少运维配置防火墙忽略了长连接?
-
长连接的使用场景当业务中客户端和服务器长时间无数据交互,空闲时间超过1800秒,会话会因超时被清除。后续客户端没有重新发起连接,直接发送控制报文时导致数据不通。常见于数据库连接。1.重点说明以天为单...
- 来,你们想要的打卡功能(有没有打卡功能)
-
前言你的世界多数情况下充满了混沌和单调,你的身体虽然不胖但并不会让你感觉到那么有力量;你的过往乏善可陈,充斥着很多伤心与自我否定,你过往的未来也没有惊喜在场。你想要一场新生,想要一次脱胎换骨,没有行...
- 关系型数据库设计要领(值得收藏)(关系型数据库的基本结构)
-
摘要本文讨论关系数据库设计相关的一些内容,涉及关系模型,表结构设计等内容,以学生选修课程讲述设计过程,在尽量讲清楚设计要领的前提下,简化设计内容。本文基于MySQL数据库为基础,适合有一定关系型数据库...
- 做表格的软件叫什么?热门表格制作软件推荐
-
作为报表开发人员,选择一款高效、易用的表格制作软件是非常重要的。这篇文章将介绍七款热门的表格制作软件,并详细介绍其中之一VeryReport报表自动生成软件的优势。1.VeryReportVeryR...
- 数据库第一二三范式到底在说什么?
-
为简单起见,并不非常严谨地区分“关系”和“数据表”的概念。首先要明白”范式(NF)”是什么意思。按照经典教材——王珊的《数据库系统概论》中的定义,范式是“符合某一种级别的关系模式的集合,表示...
- 会话粘连(Session Affinity)技术方案列表
-
会话粘连(SessionAffinity)的主要技术方案分类及典型实现:一、基于负载均衡器的会话粘连1.IP哈希(IPHash)原理:根据客户端IP地址计算哈希值,映射到固定后端服务器优点:...
你 发表评论:
欢迎- 一周热门
- 最近发表
-
- Linux下乱码的文件名修改或删除(linux文件名乱码如何处理)
- 「论文写作-解决方案」数据库TDE加密
- 数据库监控工具应具备的关键特性(数据库监控哪些指标)
- Hive的安装(Hive的安装过程通常包括哪些主要步骤?)
- 香港DM德馬大中華非遺共創集團/ 甲骨文“意”YI字写法和解释
- 香港DM德马数字甲骨文集团20240816期 甲骨文“若”RE字写法和解释
- 香港DM德马数字甲骨文集团20240812期 甲骨文“萨”SA字写法和解释
- 香港DM德馬景泰藍文科集團20250605期《無堅不摧》DMSIXSEVEN
- VirtualBox 7.0.16 权限提升漏洞(virtualbox uuid)
- 有多少运维配置防火墙忽略了长连接?
- 标签列表
-
- oracle位图索引 (74)
- oracle批量插入数据 (65)
- oracle事务隔离级别 (59)
- oracle 空为0 (51)
- 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)