MySQL是一個(gè)功能強(qiáng)大的開源數(shù)據(jù)庫。隨著越來越多的數(shù)據(jù)庫驅(qū)動(dòng)的應(yīng)用程序,人們一直在推動(dòng)MySQL發(fā)展到它的極限。這里是101條調(diào)節(jié)和優(yōu)化 MySQL安裝的技巧。一些技巧是針對特定的安裝環(huán)境的,但這些思路是通用的。我已經(jīng)把他們分成幾類,來幫助你掌握更多MySQL的調(diào)節(jié)和優(yōu)化技巧。
MySQL 服務(wù)器硬件和操作系統(tǒng)調(diào)節(jié):
1. 擁有足夠的物理內(nèi)存來把整個(gè)InnoDB文件加載到內(nèi)存中——在內(nèi)存中訪問文件時(shí)的速度要比在硬盤中訪問時(shí)快的多。
2. 不惜一切代價(jià)避免使用Swap交換分區(qū) – 交換時(shí)是從硬盤讀取的,它的速度很慢。
3. 使用電池供電的RAM(注:RAM即隨機(jī)存儲器)。
4. 使用高級的RAID(注:Redundant Arrays of Inexpensive Disks,即磁盤陣列) – 最好是RAID10或更高。
5. 避免RAID5(注:一種存儲性能、數(shù)據(jù)安全和存儲成本兼顧的存儲解決方案) – 確保數(shù)據(jù)庫完整性的校驗(yàn)是要付出代價(jià)的。
6. 將操作系統(tǒng)和數(shù)據(jù)分區(qū)分開,不僅僅是邏輯上,還包括物理上 – 操作系統(tǒng)的讀寫操作會影響數(shù)據(jù)庫的性能。
7. 把MySQL臨時(shí)空間和復(fù)制日志與數(shù)據(jù)放到不同的分區(qū) – 當(dāng)數(shù)據(jù)庫后臺從磁盤進(jìn)行讀寫操作時(shí)會影響數(shù)據(jù)庫的性能。
8. 更多的磁盤空間等于更快的速度。
17. 使用 XFS 文件系統(tǒng) – 一種比ext3更快、更小的文件系統(tǒng),并且有許多日志選項(xiàng), 而且ext3 已被證實(shí)與MySQL有雙緩沖問題。
18. 調(diào)整 XFS 文件系統(tǒng)日志和緩沖變量 – 為了最高性能標(biāo)準(zhǔn)。
19. 在 Linux 系統(tǒng)中, 使用 NOOP 或者 DEADLINE IO 定時(shí)調(diào)度程序 – 同 NOOP 和 DEADLINE定時(shí)調(diào)度程序相比,這個(gè) CFQ 和 ANTICIPATORY 定時(shí)調(diào)度程序 顯得非常慢。
20. 使用64位的操作系統(tǒng) – 對于MySQL,會有更大的內(nèi)存支持和使用。
21. 刪除服務(wù)器上未使用的安裝包和守護(hù)進(jìn)程 – 更少的資源占用。
22. 把使用MySQL的host和你的MySQL host放到一個(gè)hosts文件中 – 沒有DNS查找。
23. 切勿強(qiáng)制殺死一個(gè)MySQL進(jìn)程 – 你會損壞數(shù)據(jù)庫和正在運(yùn)行備份的程序。
24. 把服務(wù)器貢獻(xiàn)給MySQL – 后臺進(jìn)程和其他服務(wù)能夠縮短數(shù)據(jù)庫占用CPU的時(shí)間。
MySQL 配置:
25. 當(dāng)寫入時(shí),使用 innodb_flush_method=O_DIRECT 來避免雙緩沖。
26. 避免使用 O_DIRECT 和 EXT3 文件系統(tǒng) – 你將序列化所有要寫入的。
27. 分配足夠的 innodb_buffer_pool_size 來加載整個(gè) InnoDB 文件到內(nèi)存中– 少從磁盤中讀取。
28. 不要將 innodb_log_file_size 參數(shù)設(shè)置太大, 這樣可以更快同時(shí)有更多的磁盤空間 – 丟掉多的日志通常是好的,在數(shù)據(jù)庫崩潰后可以降低恢復(fù)數(shù)據(jù)庫的時(shí)間。
29. 不要混用 innodb_thread_concurrency 和 thread_concurrency 參數(shù)– 這2個(gè)值是不兼容的。
30. 分配一個(gè)極小的數(shù)量給 max_connections 參數(shù) – 太多的連接會用盡RAM并鎖定MySQL服務(wù)。
新聞熱點(diǎn)
疑難解答
圖片精選