0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫(xiě)文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

MariaDB有哪些比MySQL厲害的地方?

Linux愛(ài)好者 ? 來(lái)源:CSDN ? 作者:swanmy ? 2021-03-11 16:21 ? 次閱讀

近年來(lái),不少程序員在吹捧 MariaDB,拋棄 MySQL。本文總結(jié)了一些 MariaDB 強(qiáng)過(guò) MySQL 的地方,分享給大家!

11861ccc-7e2d-11eb-8b86-12bb97331649.jpg

MySQL 的發(fā)展史

MySQL 的歷史可以追溯到 1979 年,它的創(chuàng)始人叫作 Michael Widenius,他在開(kāi)發(fā)一個(gè)報(bào)表工具的時(shí)候,設(shè)計(jì)了一套 API。

后來(lái)他的客戶要求他的 API 支持 sql 語(yǔ)句,他直接借助于 mSQL(當(dāng)時(shí)比較牛)的代碼,將它集成到自己的存儲(chǔ)引擎中。但是他總是感覺(jué)不滿意,萌生了要自己做一套數(shù)據(jù)庫(kù)的想法。

一到 1996 年,MySQL 1.0 發(fā)布,僅僅過(guò)了幾個(gè)月的時(shí)間,1996 年 10 月 MySQL 3.11.1 當(dāng)時(shí)發(fā)布了 Solaris 的版本,一個(gè)月后,Linux 的版本誕生,從那時(shí)候開(kāi)始,MySQL 慢慢的被人所接受。

1999 年,Michael Widenius 成立了 MySQL AB 公司,MySQL 由個(gè)人開(kāi)發(fā)轉(zhuǎn)變?yōu)閳F(tuán)隊(duì)開(kāi)發(fā),2000 年使用 GPL 協(xié)議開(kāi)源。

2001 年,MySQL 生命中的大事發(fā)生了,那就是存儲(chǔ)引擎 InnoDB 的誕生!直到現(xiàn)在,MySQL 可以選擇的存儲(chǔ)引擎,InnoDB 依然是 No.1。

2008 年 1 月,MySQL AB 公司被 Sun 公司以 10 億美金收購(gòu),MySQL 數(shù)據(jù)庫(kù)進(jìn)入 Sun 時(shí)代。

Sun 為 MySQL 的發(fā)展提供了絕佳的環(huán)境,2008 年 11 月,MySQL 5.1 發(fā)布,MySQL 成為了最受歡迎的小型數(shù)據(jù)庫(kù)。

在此之前,Oracle 在 2005 年就收購(gòu)了 InnoDB,因此,InnoDB 一直以來(lái)都只能作為第三方插件供用戶選擇。

2009 年 4 月,Oracle 公司以 74 億美元收購(gòu) Sun 公司,MySQL 也隨之進(jìn)入 Oracle 時(shí)代。

2010 年 12 月,MySQL 5.5 發(fā)布,Oracle 終于把 InnoDB 做成了 MySQL 默認(rèn)的存儲(chǔ)引擎,MySQL 從此進(jìn)入了輝煌時(shí)代。

然而,從那之后,Oracle 對(duì) MySQL 的態(tài)度漸漸發(fā)生了變化,Oracle 雖然宣稱 MySQL 依然遵守 GPL 協(xié)議,但卻暗地里把開(kāi)發(fā)人員全部換成了 Oracle 自己人。

開(kāi)源社區(qū)再也影響不了 MySQL 發(fā)展的腳步,真正有心做貢獻(xiàn)的人也被拒之門(mén)外,MySQL 隨時(shí)都有閉源的可能……

橫空出世的 MariaDB 是什么鬼

先提一下 MySQL 名字的由來(lái)吧,Michael Widenius 的女兒的簡(jiǎn)稱就是 MY,Michael Widenius大 概也是把 MySQL 當(dāng)成自己的女兒吧。

看著自己辛苦養(yǎng)大的 MySQL 被 Oracle 搞成這樣,Michael Widenius 非常失望,決定在 MySQL 走向閉源前,將 MySQL 進(jìn)行分支化,依然是使用了自己女兒的名字 MariaDB(瑪莉亞 DB)。

MariaDB 數(shù)據(jù)庫(kù)管理系統(tǒng)是 MySQL 的一個(gè)分支,主要由開(kāi)源社區(qū)在維護(hù),采用 GPL 授權(quán)許可 MariaDB 的目的是完全兼容 MySQL,包括 API 和命令行,使之能輕松成為 MySQL 的代替品。

在存儲(chǔ)引擎方面,使用 XtraDB 來(lái)代替 MySQL 的 InnoDB。MariaDB 由 MySQL 的創(chuàng)始人 Michael Widenius 主導(dǎo),由開(kāi)源社區(qū)的大神們進(jìn)行開(kāi)發(fā)。

因此,大家都認(rèn)為,MariaDB 擁有比 MySQL 更純正的 MySQL 血脈。最初的版本更新與 MySQL 同步,相對(duì) MySQL5 以后的版本,MariaDB 也有相應(yīng)的 5.1~5.5 的版本。

后來(lái) MariaDB 終于擺脫了 MySQL,它的版本號(hào)直接從 10.0 開(kāi)始,以自己的步伐進(jìn)行開(kāi)發(fā),當(dāng)然,還是可以對(duì) MySQL 完全兼容。現(xiàn)在,MariaDB 的數(shù)據(jù)特性、性能等都超越了 MySQL。

測(cè)試環(huán)境

本性能測(cè)試環(huán)境如下:

CPU:I7

內(nèi)存:8G

OS:Windows 10 64位

硬盤(pán)類型:SSD

MySQL:8.0.19

MariaDB:10.4.12

分別在 MySQl 和 MariaDB 中創(chuàng)建名為 performance 的數(shù)據(jù)庫(kù),并創(chuàng)建 log 表,都使用 innodb 作為數(shù)據(jù)庫(kù)引擎:

CREATE TABLE `performance`。`log`( `id` INT UNSIGNED NOT NULL AUTO_INCREMENT, `time` DATETIME NOT NULL, `level` ENUM(‘info’,‘debug’,‘error’) NOT NULL, `message` TEXT NOT NULL, PRIMARY KEY (`id`) ) ENGINE=INNODB CHARSET=utf8;

插入性能

單條插入

單條插入的測(cè)試結(jié)果如下表所示:

128aedb4-7e2d-11eb-8b86-12bb97331649.png

MariaDB 單條數(shù)據(jù)插入的性能比 MySQL 強(qiáng) 1 倍左右。

批量插入

批量插入的測(cè)試結(jié)果如下表所示:

12d40562-7e2d-11eb-8b86-12bb97331649.png

上面的測(cè)試結(jié)果,MariaDB 并沒(méi)有絕對(duì)優(yōu)勢(shì),甚至有時(shí)還比 MySQL 慢,但平均水平還是高于 MySQL。

查詢性能

經(jīng)過(guò)了多次插入測(cè)試,我兩個(gè)數(shù)據(jù)庫(kù)里插入了很多數(shù)據(jù),此時(shí)用下面的 sql 查詢表中的數(shù)據(jù)量:

SELECT COUNT(0) FROM LOG

結(jié)果兩個(gè)表都是 6785000 條,MariaDB 用時(shí) 3.065 秒,MySQL 用時(shí) 6.404 秒。

此時(shí)我機(jī)器的內(nèi)存用了 6 個(gè) G,MariaDB 用了 474284 K,MySQL 只用了 66848 K??磥?lái) MariaDB 快是犧牲了空間換取的。

無(wú)索引

先查詢一下 time 字段的最大值和最小值:

SELECT MAX(TIME), MIN(TIME) FROM LOG

MariaDB 用時(shí) 6.333 秒,MySQL 用時(shí) 8.159 秒。接下來(lái)測(cè)試過(guò)濾 time 字段在 0 點(diǎn)到 1 點(diǎn)之間的數(shù)據(jù),并對(duì) time 字段排序:

SELECT * FROM LOG WHERE TIME 》 ‘2020-02-04 0000’ AND TIME 《 ‘2020-02-04 0100’ ORDER BY TIME

MariaDB 用時(shí) 6.996 秒,MySQL 用時(shí) 10.193 秒。然后測(cè)試查詢 level 字符是 info 的數(shù)據(jù):

SELECT * FROM LOG WHERE LEVEL = ‘info’

MariaDB 用時(shí) 0.006 秒,MySQL 用時(shí) 0.049 秒。最后測(cè)試查詢 message 字段值為 debug 的數(shù)據(jù):

SELECT * FROM LOG WHERE MESSAGE = ‘debug’ MariaDB 用時(shí) 0.003 秒,MySQL 用時(shí) 0.004 秒。

索引

分別對(duì)兩個(gè)數(shù)據(jù)庫(kù)的字段創(chuàng)建索引:

ALTER TABLE `performance`。`log` ADD INDEX `time` (`time`), ADD INDEX `level` (`level`), ADD FULLTEXT INDEX `message` (`message`);

MariaDB 用時(shí) 2 分 47 秒,MySQL 用時(shí) 3 分 48 秒。再用上面的測(cè)試項(xiàng)目進(jìn)行測(cè)試,結(jié)果如下表所示:

130cedb4-7e2d-11eb-8b86-12bb97331649.png

有些結(jié)果添加了索引后還不如不加索引時(shí)理想,說(shuō)明實(shí)際使用時(shí)并不是每個(gè)字段都需要添加索引的。

總結(jié)

在上面的測(cè)試中 MariaDB 的性能的確優(yōu)于 MySQL,看來(lái)各大廠商放棄 MySQL 擁抱 MariaDB 還是非常有道理的。

原文標(biāo)題:吊打MySQL,MariaDB到底強(qiáng)在哪?

文章出處:【微信公眾號(hào):Linux愛(ài)好者】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。

責(zé)任編輯:haq

聲明:本文內(nèi)容及配圖由入駐作者撰寫(xiě)或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問(wèn)題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • MySQL
    +關(guān)注

    關(guān)注

    1

    文章

    794

    瀏覽量

    26359

原文標(biāo)題:吊打MySQL,MariaDB到底強(qiáng)在哪?

文章出處:【微信號(hào):LinuxHub,微信公眾號(hào):Linux愛(ài)好者】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。

收藏 人收藏

    評(píng)論

    相關(guān)推薦

    MySQL知識(shí)點(diǎn)匯總

    大家好,這部分被稱為DQL部分,是每個(gè)學(xué)習(xí)MySQL必須要學(xué)會(huì)的部分,下面就讓我來(lái)介紹MySQL中的其他部分。
    的頭像 發(fā)表于 08-05 15:27 ?329次閱讀
    <b class='flag-5'>MySQL</b>知識(shí)點(diǎn)匯總

    在AvaotaA1全志T527開(kāi)發(fā)板上使用AvaotaOS 部署 LNMP 服務(wù)

    ,會(huì)出現(xiàn)如下提示: 目前提供了較多的MySQL、MariaDB版本和不安裝數(shù)據(jù)庫(kù)的選項(xiàng),需要 注意的是MySQL 5.6,5.7及MariaDB 10如果是編譯安裝必須在1G以上內(nèi)存
    發(fā)表于 07-05 10:01

    MySQL的整體邏輯架構(gòu)

    支持多種存儲(chǔ)引擎是眾所周知的MySQL特性,也是MySQL架構(gòu)的關(guān)鍵優(yōu)勢(shì)之一。如果能夠理解MySQL Server與存儲(chǔ)引擎之間是怎樣通過(guò)API交互的,將大大有利于理解MySQL的核心
    的頭像 發(fā)表于 04-30 11:14 ?388次閱讀
    <b class='flag-5'>MySQL</b>的整體邏輯架構(gòu)

    使用cpolar內(nèi)網(wǎng)穿透本地MariaDB數(shù)據(jù)庫(kù)

    本篇教程將使用cpolar內(nèi)網(wǎng)穿透本地MariaDB數(shù)據(jù)庫(kù),并實(shí)現(xiàn)在外公網(wǎng)環(huán)境下使用navicat圖形化工具遠(yuǎn)程連接本地內(nèi)網(wǎng)的MariaDB數(shù)據(jù)庫(kù)。
    的頭像 發(fā)表于 01-22 10:28 ?525次閱讀
    使用cpolar內(nèi)網(wǎng)穿透本地<b class='flag-5'>MariaDB</b>數(shù)據(jù)庫(kù)

    MySQL密碼忘記了怎么辦?MySQL密碼快速重置方法步驟命令示例!

    MySQL密碼忘記了怎么辦?MySQL密碼快速重置方法步驟命令示例! MySQL是一種常用的關(guān)系型數(shù)據(jù)庫(kù)管理系統(tǒng),如果你忘記了MySQL的密碼,不必?fù)?dān)心,可以通過(guò)一些簡(jiǎn)單的步驟來(lái)快速重
    的頭像 發(fā)表于 01-12 16:06 ?681次閱讀

    如何使用Golang連接MySQL

    首先我們來(lái)看如何使用Golang連接MySQL
    的頭像 發(fā)表于 01-08 09:42 ?3114次閱讀
    如何使用Golang連接<b class='flag-5'>MySQL</b>

    mysql密碼忘了怎么重置

    mysql密碼忘了怎么重置? MySQL是一種開(kāi)源的關(guān)系型數(shù)據(jù)庫(kù)管理系統(tǒng),密碼用于保護(hù)數(shù)據(jù)庫(kù)的安全性和保密性。如果你忘記了MySQL的密碼,可以通過(guò)以下幾種方法進(jìn)行重置。 方法一:使用MySQ
    的頭像 發(fā)表于 12-27 16:51 ?5434次閱讀

    mysql數(shù)據(jù)庫(kù)基礎(chǔ)命令

    MySQL是一個(gè)流行的關(guān)系型數(shù)據(jù)庫(kù)管理系統(tǒng),經(jīng)常用于存儲(chǔ)、管理和操作數(shù)據(jù)。在本文中,我們將詳細(xì)介紹MySQL的基礎(chǔ)命令,并提供與每個(gè)命令相關(guān)的詳細(xì)解釋。 登錄MySQL 要登錄MySQL
    的頭像 發(fā)表于 12-06 10:56 ?512次閱讀

    php的mysql無(wú)法啟動(dòng)

    MySQL是一種常用的關(guān)系型數(shù)據(jù)庫(kù)管理系統(tǒng),而PHP是一種廣泛應(yīng)用于服務(wù)器端的腳本語(yǔ)言。在使用PHP開(kāi)發(fā)網(wǎng)站或應(yīng)用時(shí),經(jīng)常會(huì)碰到MySQL無(wú)法啟動(dòng)的問(wèn)題。本文將詳細(xì)介紹解決MySQL無(wú)法啟動(dòng)的方法
    的頭像 發(fā)表于 12-04 15:59 ?1283次閱讀

    MySQL常用語(yǔ)句

    MySQL是一個(gè)關(guān)系型數(shù)據(jù)庫(kù)管理系統(tǒng),廣泛應(yīng)用于Web應(yīng)用程序的開(kāi)發(fā)以及數(shù)據(jù)管理領(lǐng)域。在使用MySQL時(shí),一些常用的語(yǔ)句可以幫助我們進(jìn)行數(shù)據(jù)的操作和管理。接下來(lái),我將詳細(xì)介紹MySQL
    的頭像 發(fā)表于 11-21 11:11 ?457次閱讀

    mysql和sql server區(qū)別

    MySQL和SQL Server是兩種常見(jiàn)的關(guān)系型數(shù)據(jù)庫(kù)管理系統(tǒng)(RDBMS),用于存儲(chǔ)和管理數(shù)據(jù)庫(kù)。雖然它們都支持SQL語(yǔ)言,但在其他方面存在一些顯著的區(qū)別。以下是MySQL和SQL Server
    的頭像 發(fā)表于 11-21 11:07 ?1398次閱讀

    MySQL導(dǎo)出的步驟

    MySQL是一種常用的關(guān)系型數(shù)據(jù)庫(kù)管理系統(tǒng),用于存儲(chǔ)和管理大量的結(jié)構(gòu)化數(shù)據(jù)。在實(shí)際應(yīng)用中,我們經(jīng)常需要將MySQL數(shù)據(jù)庫(kù)中的數(shù)據(jù)導(dǎo)出到其他地方,如備份數(shù)據(jù)、數(shù)據(jù)遷移、數(shù)據(jù)分析等。下面是使用My
    的頭像 發(fā)表于 11-21 10:58 ?710次閱讀

    MySQL中增刪改查的例子

    MySQL是一種常用的關(guān)系型數(shù)據(jù)庫(kù)管理系統(tǒng),它具有強(qiáng)大的數(shù)據(jù)處理和數(shù)據(jù)存儲(chǔ)能力。在MySQL中,我們可以使用各種命令來(lái)進(jìn)行數(shù)據(jù)的增加、刪除、修改和查詢操作。下面將詳細(xì)介紹MySQL中各個(gè)操作的實(shí)例
    的頭像 發(fā)表于 11-16 15:39 ?657次閱讀

    mysql主從復(fù)制 混合類型的復(fù)制

    使用行級(jí)復(fù)制和語(yǔ)句級(jí)復(fù)制。本文將詳細(xì)介紹MySQL主從復(fù)制的概念、原理、配置步驟以及優(yōu)缺點(diǎn),并重點(diǎn)討論混合類型復(fù)制的實(shí)現(xiàn)和應(yīng)用。希望通過(guò)本文的闡述,能使讀者對(duì)MySQL主從復(fù)制混合類型復(fù)制更全面的了解。 1.
    的頭像 發(fā)表于 11-16 14:20 ?501次閱讀

    為什么MySQL備份很重要?MySQL備份類型哪些?

    MySQL 備份和恢復(fù)策略,它們是任何應(yīng)用程序的基石。對(duì)應(yīng)您的特定場(chǎng)景,多個(gè)選項(xiàng)可供選擇,每個(gè)選項(xiàng)都要求我們考慮相關(guān)問(wèn)題以做出明智的決策。
    的頭像 發(fā)表于 11-14 10:20 ?599次閱讀