一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務器之家:專注于服務器技術及軟件下載分享
分類導航

Mysql|Sql Server|Oracle|Redis|MongoDB|PostgreSQL|Sqlite|DB2|mariadb|Access|數據庫技術|

服務器之家 - 數據庫 - Mysql - MySQL數據庫三種常用存儲引擎特性對比

MySQL數據庫三種常用存儲引擎特性對比

2020-05-29 16:22MYSQL教程網 Mysql

MySQL中的數據用各種不同的技術存儲在文件(或內存)中,這些技術中的每一種技術都使用不同的存儲機制,索引技巧,鎖定水平并且最終提供廣泛的不同功能和能力。在MySQL中將這些不同的技術及配套的相關功能稱為存儲引擎。

MySQL 的存儲引擎可能是所有關系型數據庫產品中最具有特色的了,不僅可以同時使用多種存儲引擎,而且每種存儲引擎和MySQL之間使用插件方式這種非常松的耦合關系。

由于各存儲引擎功能特性差異較大,這篇文章主要是介紹如何來選擇合適的存儲引擎來應對不同的業務場景。

MyISAM

特性
不支持事務:MyISAM存儲引擎不支持事務,所以對事務有要求的業務場景不能使用
表級鎖定:其鎖定機制是表級索引,這雖然可以讓鎖定的實現成本很小但是也同時大大降低了其并發性能
讀寫互相阻塞:不僅會在寫入的時候阻塞讀取,MyISAM還會在讀取的時候阻塞寫入,但讀本身并不會阻塞另外的讀
只會緩存索引:MyISAM可以通過key_buffer緩存以大大提高訪問性能減少磁盤IO,但是這個緩存區只會緩存索引,而不會緩存數據

適用場景
不需要事務支持(不支持)
并發相對較低(鎖定機制問題)
數據修改相對較少(阻塞問題)
以讀為主
數據一致性要求不是非常高

最佳實踐
盡量索引(緩存機制)
調整讀寫優先級,根據實際需求確保重要操作更優先
啟用延遲插入改善大批量寫入性能
盡量順序操作讓insert數據都寫入到尾部,減少阻塞
分解大的操作,降低單個操作的阻塞時間
降低并發數,某些高并發場景通過應用來進行排隊機制
對于相對靜態的數據,充分利用Query Cache可以極大的提高訪問效率
MyISAM的Count只有在全表掃描的時候特別高效,帶有其他條件的count都需要進行實際的數據訪問

InnoDB

特性
具有較好的事務支持:支持4個事務隔離級別,支持多版本讀
行級鎖定:通過索引實現,全表掃描仍然會是表鎖,注意間隙鎖的影響
讀寫阻塞與事務隔離級別相關
具有非常高效的緩存特性:能緩存索引,也能緩存數據
整個表和主鍵以Cluster方式存儲,組成一顆平衡樹
所有Secondary Index都會保存主鍵信息

適用場景
需要事務支持(具有較好的事務特性)
行級鎖定對高并發有很好的適應能力,但需要確保查詢是通過索引完成
數據更新較為頻繁的場景
數據一致性要求較高
硬件設備內存較大,可以利用InnoDB較好的緩存能力來提高內存利用率,盡可能減少磁盤 IO

最佳實踐
主鍵盡可能小,避免給Secondary index帶來過大的空間負擔
避免全表掃描,因為會使用表鎖
盡可能緩存所有的索引和數據,提高響應速度
在大批量小插入的時候,盡量自己控制事務而不要使用autocommit自動提交
合理設置innodb_flush_log_at_trx_commit參數值,不要過度追求安全性
避免主鍵更新,因為這會帶來大量的數據移動

NDBCluster

特性
分布式:分布式存儲引擎,可以由多個NDBCluster存儲引擎組成集群分別存放整體數據的一部分
支持事務:和Innodb一樣,支持事務
可與mysqld不在一臺主機:可以和mysqld分開存在于獨立的主機上,然后通過網絡和mysqld通信交互
內存需求量巨大:新版本索引以及被索引的數據必須存放在內存中,老版本所有數據和索引必須存在與內存中

適用場景
具有非常高的并發需求
對單個請求的響應并不是非常的critical
查詢簡單,過濾條件較為固定,每次請求數據量較少,又不希望自己進行水平Sharding

最佳實踐
盡可能讓查詢簡單,避免數據的跨節點傳輸
盡可能滿足SQL節點的計算性能,大一點的集群SQL節點會明顯多余Data節點
在各節點之間盡可能使用萬兆網絡環境互聯,以減少數據在網絡層傳輸過程中的延時

注:以上三個存儲引擎是目前相對主流的存儲引擎,還有其他類似如:Memory,Merge,CSV,Archive等存儲引擎的使用場景都相對較少,這里就不一一分析了。

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 久久永久免费视频 | 成人午夜爽爽爽免费视频 | 好 舒服 好 粗 好硬免费视频 | 亚洲欧美自偷自拍另类小说 | 末代皇帝无删减版在线观看 | 99草视频 | 深夜福利影院在线观看 | 免费在线观看a | 国产草| 成人免费视屏 | 小SAO货边洗澡边CAO你动漫 | 久久99精国产一区二区三区四区 | 女人把私密部位张开让男人桶 | 亚洲国产第一 | 亚洲图片一区二区三区 | 无颜之月全集免费观看 | caopren免费视频国产 | 日本 在线观看 | 色久天| 天天曰| 嫩草影院永久在线一二三四 | 国产在线三级 | 久久九九有精品国产23百花影院 | 免费看成人毛片日本久久 | 精品一区二区高清在线观看 | 无人区在线观看免费观看 | 韩国三级在线观看 完整版 韩国三级视频网站 | 四虎影在线永久免费观看 | 精品网站一区二区三区网站 | 精品无人乱码一区二区三区 | 亚洲精品一区在线观看 | 99热精品在线免费观看 | 果冻传媒在线免费观看 | 精品午夜寂寞影院在线观看 | 亚洲成人国产精品 | 爱情岛论坛亚洲自拍 | gay勾搭直男com | 啊皇上你好大要知画 | 亚洲精品久久久久久婷婷 | 水蜜臀| 激情另类国内一区二区视频 |