成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

吊打MySQL,MariaDB到底強在哪?

數據庫 MySQL MariaDB
近年來,不少程序員在吹捧 MariaDB,拋棄 MySQL。本文總結了一些 MariaDB 強過 MySQL 的地方,分享給大家!

[[383750]]

圖片來自 Pexels  

 

MySQL 的發展史

MySQL 的歷史可以追溯到 1979 年,它的創始人叫作 Michael Widenius,他在開發一個報表工具的時候,設計了一套 API。

后來他的客戶要求他的 API 支持 sql 語句,他直接借助于 mSQL(當時比較牛)的代碼,將它集成到自己的存儲引擎中。但是他總是感覺不滿意,萌生了要自己做一套數據庫的想法。

 

一到 1996 年,MySQL 1.0 發布,僅僅過了幾個月的時間,1996 年 10 月 MySQL 3.11.1 當時發布了 Solaris 的版本,一個月后,Linux 的版本誕生,從那時候開始,MySQL 慢慢的被人所接受。

1999 年,Michael Widenius 成立了 MySQL AB 公司,MySQL 由個人開發轉變為團隊開發,2000 年使用 GPL 協議開源。

2001 年,MySQL 生命中的大事發生了,那就是存儲引擎 InnoDB 的誕生!直到現在,MySQL 可以選擇的存儲引擎,InnoDB 依然是 NO.1。

2008 年 1 月,MySQL AB 公司被 Sun 公司以 10 億美金收購,MySQL 數據庫進入 Sun 時代。

Sun 為 MySQL 的發展提供了絕佳的環境,2008 年 11 月,MySQL 5.1 發布,MySQL 成為了最受歡迎的小型數據庫。

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

2009 年 4 月,Oracle 公司以 74 億美元收購 Sun 公司,MySQL 也隨之進入 Oracle 時代。

2010 年 12 月,MySQL 5.5 發布,Oracle 終于把 InnoDB 做成了 MySQL 默認的存儲引擎,MySQL 從此進入了輝煌時代。

然而,從那之后,Oracle 對 MySQL 的態度漸漸發生了變化,Oracle 雖然宣稱 MySQL 依然尊少 GPL 協議,但卻暗地里把開發人員全部換成了 Oracle 自己人。

開源社區再也影響不了 MySQL 發展的腳步,真正有心做貢獻的人也被拒之門外,MySQL 隨時都有閉源的可能……

橫空出世的 MariaDB 是什么鬼

先提一下 MySQL 名字的由來吧,Michael Widenius 的女兒的簡稱就是 MY,Michael Widenius大 概也是把 MySQL 當成自己的女兒吧。

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

MariaDB 數據庫管理系統是 MySQL 的一個分支,主要由開源社區在維護,采用 GPL 授權許可 MariaDB 的目的是完全兼容 MySQL,包括 API 和命令行,使之能輕松成為 MySQL 的代替品。

在存儲引擎方面,使用 XtraDB 來代替 MySQL 的 InnoDB。MariaDB 由 MySQL 的創始人 Michael Widenius 主導,由開源社區的大神們進行開發。

因此,大家都認為,MariaDB 擁有比 MySQL 更純正的 MySQL 血脈。最初的版本更新與 MySQL 同步,相對 MySQL5 以后的版本,MariaDB 也有相應的 5.1~5.5 的版本。

后來 MariaDB 終于擺脫了 MySQL,它的版本號直接從 10.0 開始,以自己的步伐進行開發,當然,還是可以對 MySQL 完全兼容。現在,MariaDB 的數據特性、性能等都超越了 MySQL。

 

測試環境

本性能測試環境如下:

  • CPU:I7
  • 內存:8G
  • OS:Windows 10 64位
  • 硬盤類型:SSD
  • MySQL:8.0.19
  • MariaDB:10.4.12

分別在 MySQl 和 MariaDB 中創建名為 performance 的數據庫,并創建 log 表,都使用 innodb 作為數據庫引擎:

  1. CREATE TABLE `performance`.`log`(   
  2.   `id` INT UNSIGNED NOT NULL AUTO_INCREMENT, 
  3.   `time` DATETIME NOT NULL
  4.   `level` ENUM('info','debug','error'NOT NULL
  5.   `message` TEXT NOT NULL
  6.   PRIMARY KEY (`id`) 
  7. ) ENGINE=INNODB CHARSET=utf8; 

插入性能

單條插入

單條插入的測試結果如下表所示:

 

MariaDB 單條數據插入的性能比 MySQL 強 1 倍左右。

批量插入

批量插入的測試結果如下表所示:

 

上面的測試結果,MariaDB 并沒有絕對優勢,甚至有時還比 MySQL 慢,但平均水平還是高于 MySQL。

查詢性能

經過了多次插入測試,我兩個數據庫里插入了很多數據,此時用下面的 sql 查詢表中的數據量:

  1. SELECT COUNT(0) FROM LOG 

結果兩個表都是 6785000 條,MariaDB 用時 3.065 秒,MySQL 用時 6.404 秒。

此時我機器的內存用了 6 個 G,MariaDB 用了 474284 K,MySQL 只用了 66848 K。看來 MariaDB 快是犧牲了空間換取的。

無索引

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

  1. SELECT MAX(TIME), MIN(TIMEFROM LOG 

MariaDB 用時 6.333 秒,MySQL 用時 8.159 秒。接下來測試過濾 time 字段在 0 點到 1 點之間的數據,并對 time 字段排序:

  1. SELECT * FROM LOG WHERE TIME > '2020-02-04 00:00:00' AND TIME < '2020-02-04 01:00:00' ORDER BY TIME 

MariaDB 用時 6.996 秒,MySQL 用時 10.193 秒。然后測試查詢 level 字符是 info 的數據:

  1. SELECT * FROM LOG WHERE LEVEL = 'info' 

MariaDB 用時 0.006 秒,MySQL 用時 0.049 秒。最后測試查詢 message 字段值為 debug 的數據:

  1. SELECT * FROM LOG WHERE MESSAGE = 'debug' 

MariaDB 用時 0.003 秒,MySQL 用時 0.004 秒。

有索引

分別對兩個數據庫的字段創建索引:

  1. ALTER TABLE `performance`.`log`    
  2.   ADD  INDEX `time` (`time`), 
  3.   ADD  INDEX `level` (`level`), 
  4.   ADD FULLTEXT INDEX `message` (`message`); 

MariaDB 用時 2 分 47 秒,MySQL 用時 3 分 48 秒。再用上面的測試項目進行測試,結果如下表所示:

 

有些結果添加了索引后還不如不加索引時理想,說明實際使用時并不是每個字段都需要添加索引的。

總結

在上面的測試中 MariaDB 的性能的確優于 MySQL,看來各大廠商放棄 MySQL 擁抱 MariaDB 還是非常有道理的。

作者:swanmy

編輯:陶家龍

出處:http://r6d.cn/b27qt

 

責任編輯:武曉燕 來源: /r6d.cn
相關推薦

2017-06-22 16:18:58

IBM光譜存儲軟件定義存儲

2019-05-22 10:38:00

5G芯片中興

2012-09-13 14:11:07

Windows Ser微軟云平臺

2021-10-08 14:43:24

WiFi 5WiFi 6遠程

2017-11-30 14:14:53

2021-12-15 06:58:28

RedisEhCache緩存

2021-10-06 19:02:36

Keil編譯器Armclang

2024-04-10 08:15:17

模型語言模型GPT

2020-10-30 12:41:14

PostgreSQL數據庫MySQL

2020-04-30 11:11:30

MySQLMGR數據庫

2016-11-21 17:27:04

Android 推送

2021-07-26 08:12:31

開源API網關

2021-12-01 07:26:12

AIOps企業

2020-11-27 10:16:10

Java反射代碼

2014-01-07 13:54:40

Hadoop日志

2024-11-05 09:32:47

2016-08-25 08:58:36

云計算阿里云騰訊云

2020-08-06 09:08:51

開發谷歌微軟

2017-03-16 14:31:11

點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 欧美亚洲视频在线观看 | 国产精品久久久久久久免费观看 | 色在线视频网站 | 久久国产精品免费一区二区三区 | 日本网站免费观看 | 久久999 | 91 久久| 影音先锋久久 | 国产免费一区二区三区最新6 | 91影视 | 日韩毛片在线免费观看 | 午夜精品一区 | 亚洲视频手机在线 | 欧美在线视频网站 | 欧美成人h版在线观看 | 成人免费观看男女羞羞视频 | 亚洲人成人一区二区在线观看 | 99国产在线| 日韩av大片免费看 | 亚洲欧美日韩在线不卡 | 天堂av中文| 久综合| 久久国产电影 | 在线亚洲欧美 | 久久精品视频在线免费观看 | 欧美一级在线观看 | 91社区在线观看高清 | 国产成人一区二区三区电影 | 久久一区二区三区电影 | 中文字幕1区2区3区 日韩在线视频免费观看 | 北条麻妃99精品青青久久主播 | 精品美女久久久 | 成人精品视频 | 无码日韩精品一区二区免费 | 精品日韩一区二区 | 免费国产一区二区 | 午夜在线电影网 | 看片91 | 成人免费黄视频 | www.一区二区 | 欧美日韩在线视频一区 |