存储引擎:MySQL系列之七
一、MyISAM存儲引擎
缺點:
優(yōu)點:
MyISAM引擎存儲文件:
- tbl_name.frm: 表格式定義
- tbl_name.MYD: 數(shù)據(jù)文件
- tbl_name.MYI: 索引文件
適用場景:MySQL5.5.5前默認(rèn)的數(shù)據(jù)庫引擎,在只讀(或者寫較少)、表較小(可以接受長時間進行修復(fù)操作)的場景適用
二:InnoDB存儲引擎
特點:
InnoDB數(shù)據(jù)庫文件:
- tb_name.frm:表格式定義
- tb_name.ibd :數(shù)據(jù)文件
注意:默認(rèn)所有的innodb表數(shù)據(jù)文件存儲在數(shù)據(jù)庫目錄下的ibddata1, ibddata2, ... ,這樣極其不方便管理
強烈建議:啟用 innodb_file_per_table=ON,每個表單獨使用一個表空間存儲表的數(shù)據(jù)和索引
啟用:innodb_file_per_table
編輯/etc/my.cnf在[mysqld]下添加 innodb_file_per_table 重啟服務(wù)器 # service mysqld restart MariaDB [(none)]> SHOW VARIABLES LIKE 'innodb_file_per_table'; +-----------------------+-------+ | Variable_name | Value | +-----------------------+-------+ | innodb_file_per_table | ON | +-----------------------+-------+1、管理存儲引擎
查看mysql支持的存儲引擎: MariaDB [(none)]> SHOW ENGINES\G
查看當(dāng)前默認(rèn)的存儲引擎:
MariaDB [(none)]> SHOW VARIABLES LIKE 'storage_engine'; +----------------+--------+ | Variable_name | Value | +----------------+--------+ | storage_engine | InnoDB | +----------------+--------+設(shè)置默認(rèn)的存儲引擎:
編輯/etc/my.conf在[mysqld]下添加 default_storage_engine = InnoDB2、InnoDB存儲引擎的緩存
InnoDB存儲引擎的緩沖池通常緩沖池的命中不應(yīng)該小于99%
相關(guān)狀態(tài)變量:
MariaDB [(none)]> SHOW GLOBAL STATUS LIKE 'innodb%read%'\G- Innodb_buffer_pool_reads: 表示從物理磁盤讀取頁的次數(shù)
- Innodb_buffer_pool_read_ahead: 預(yù)讀的次數(shù)
- Innodb_buffer_pool_read_ahead_evicted: 預(yù)讀頁,但是沒有讀取就從緩沖池中被替換的頁數(shù)量,一般用來判斷預(yù)讀的效率
- Innodb_buffer_pool_read_requests: 從緩沖池中讀取頁次數(shù)
- Innodb_data_read: 總共讀入的字節(jié)數(shù)
- Innodb_data_reads: 發(fā)起讀取請求的次數(shù),每次讀取可能需要讀取多個頁
Innodb緩沖池命中率 = Innodb_buffer_pool_read_requests / ( Innodb_buffer_pool_read_requests + Innodb_buffer_pool_read_ahead + Innodb_buffer_pool_reads )
平均每次讀取的字節(jié)數(shù) = Innodb_data_read / Innodb_data_reads
三、其他存儲引擎
- Performance_Schema:Performance_Schema數(shù)據(jù)庫;
- Memory :將所有數(shù)據(jù)存儲在RAM中,以便在需要快速查找參考和其他類似數(shù)據(jù)的環(huán)境中進行快速訪問。適用存放臨時數(shù)據(jù)。引擎以前被稱為HEAP引擎;
- MRG_MyISAM:使MySQL DBA或開發(fā)人員能夠?qū)σ幌盗邢嗤腗yISAM表進行邏輯分組,并將它們作為一個對象引用。適用于VLDB(Very Large Data Base)環(huán)境,如數(shù)據(jù)倉庫;
- Archive :為存儲和檢索大量很少參考的存檔或安全審核信息,只支持SELECT和INSERT操作;支持行級鎖和專用緩存區(qū);
- Federated聯(lián)合:用于訪問其它遠程MySQL服務(wù)器一個代理,它通過創(chuàng)建一個到遠程MySQL服務(wù)器的客戶端連接,并將查詢傳輸?shù)竭h程服務(wù)器執(zhí)行,而后完成數(shù)據(jù)存取,提供鏈接單獨MySQL服務(wù)器的能力,以便從多個物理服務(wù)器創(chuàng)建一個邏輯數(shù)據(jù)庫。非常適合分布式或數(shù)據(jù)集市環(huán)境;
- BDB:可替代InnoDB的事務(wù)引擎,支持COMMIT、ROLLBACK和其他事務(wù)特性;
- Cluster/NDB:MySQL的簇式數(shù)據(jù)庫引擎,尤其適合于具有高性能查找要求的應(yīng)用程序,這類查找需求還要求具有最高的正常工作時間和可用性;
- CSV:CSV存儲引擎使用逗號分隔值格式將數(shù)據(jù)存儲在文本文件中。可以使用CSV引擎以CSV格式導(dǎo)入和導(dǎo)出其他軟件和應(yīng)用程序之間的數(shù)據(jù)交換;
- BLACKHOLE :黑洞存儲引擎接受但不存儲數(shù)據(jù),檢索總是返回一個空集。該功能可用于分布式數(shù)據(jù)庫設(shè)計,數(shù)據(jù)自動復(fù)制,但不是本地存儲;
- example:“stub”引擎,它什么都不做。可以使用此引擎創(chuàng)建表,但不能將數(shù)據(jù)存儲在其中或從中檢索。目的是作為例子來說明如何開始編寫新的存儲引擎。
轉(zhuǎn)載于:https://www.cnblogs.com/L-dongf/p/9160665.html
總結(jié)
以上是生活随笔為你收集整理的存储引擎:MySQL系列之七的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: Windows Subsystem fo
- 下一篇: run as gradle test,未