一. 優(yōu)化介紹
在進行優(yōu)化講解之前,健哥鄭重的和各位小伙伴說。本課程只是給大家提供一些優(yōu)化方面的方向和思路,而具體業(yè)務(wù)場景的不同,使用的MySQL服務(wù)版本不同,都會使得優(yōu)化方案的制定也不同。優(yōu)化不存在按照某種方式去做就一定好用的絕對真理。
MySQL介紹
MySQL憑借著出色的性能、低廉的成本、豐富的資源,已經(jīng)成為絕大多數(shù)互聯(lián)網(wǎng)公司的首選關(guān)系型數(shù)據(jù)庫??梢钥吹紾oogle,F(xiàn)acebook,Twitter,百度,新浪,騰訊,淘寶,網(wǎng)易,久游等絕大多數(shù)互聯(lián)網(wǎng)公司數(shù)據(jù)庫都是用的MySQL數(shù)據(jù)庫,甚至將其作為核心應(yīng)用的數(shù)據(jù)庫系統(tǒng)。
我們知道一般的應(yīng)用系統(tǒng),讀寫比例在10:1左右,而且插入操作和一般的更新操作很少出現(xiàn)性能問題,遇到最多的,也是最容易出問題的,還是一些復(fù)雜的查詢操作,所以查詢語句的優(yōu)化顯然是重中之重。
我們將這里進行一個較為全面的分析,讓大家了解到MySQL的性能到底與哪些地方有關(guān),以便于讓大家尋找出其性能問題的根本原因,而盡可能清楚的知道該如何去優(yōu)化自己的數(shù)據(jù)庫。
優(yōu)化可能帶來的問題
● 優(yōu)化不總是對一個單純的環(huán)境進行,還很可能是一個復(fù)雜的已投產(chǎn)的系統(tǒng)!
● 優(yōu)化手段有很大的風(fēng)險,一定要意識到和預(yù)見到!
● 任何的技術(shù)可以解決一個問題,但必然存在帶來一個問題的風(fēng)險!
● 對于優(yōu)化來說調(diào)優(yōu)而帶來的問題,控制在可接受的范圍內(nèi)才是有成果。
● 保持現(xiàn)狀或出現(xiàn)更差的情況都是失敗!
優(yōu)化的需求
● 穩(wěn)定性和業(yè)務(wù)可持續(xù)性,通常比性能更重要!
● 優(yōu)化不可避免涉及到變更,變更就有風(fēng)險!
● 優(yōu)化使性能變好,維持和變差是等概率事件!
● 優(yōu)化應(yīng)該是各部門協(xié)同,共同參與的工作,任何單一部門都不能對數(shù)據(jù)庫進行優(yōu)化!
優(yōu)化由誰參與
在進行數(shù)據(jù)庫優(yōu)化時,應(yīng)由數(shù)據(jù)庫管理員、業(yè)務(wù)部門代表、應(yīng)用程序架構(gòu)師、應(yīng)用程序設(shè)計人員、應(yīng)用程序開發(fā)人員、硬件及系統(tǒng)管理員、存儲管理員等,業(yè)務(wù)相關(guān)人員共同參與。
優(yōu)化的方向
在數(shù)據(jù)庫優(yōu)化上有兩個主要方向:即安全與性能。
安全:數(shù)據(jù)安全性。
性能:數(shù)據(jù)的高性能訪問。
本課程主要是在性能優(yōu)化方向進行介紹。
優(yōu)化的維度
從上圖中可以看出,我們把數(shù)據(jù)庫優(yōu)化分為四個緯度:硬件,系統(tǒng)配置,數(shù)據(jù)庫表結(jié)構(gòu),SQL及索引。
硬件: CPU、內(nèi)存、存儲、網(wǎng)絡(luò)設(shè)備等。
系統(tǒng)配置: 服務(wù)器系統(tǒng)、數(shù)據(jù)庫服務(wù)參數(shù)等。
數(shù)據(jù)庫表結(jié)構(gòu): 高可用、分庫分表、讀寫分離、存儲引擎、表設(shè)計等。
SQL及索引: sql語句、索引使用等。
從優(yōu)化成本進行考慮:硬件>系統(tǒng)配置>數(shù)據(jù)庫表結(jié)構(gòu)>SQL及索引。
從優(yōu)化效果進行考慮:硬件<系統(tǒng)配置<數(shù)據(jù)庫表結(jié)構(gòu)<sql及索引。< p="">
數(shù)據(jù)庫使用優(yōu)化思路
健哥在這里盡可能的全面介紹數(shù)據(jù)庫的調(diào)優(yōu)思路,但是在多數(shù)時候,我們進行調(diào)優(yōu)不需要進行這么全面、大范圍的調(diào)優(yōu),一般情況下,我們進行數(shù)據(jù)庫層面的優(yōu)化就可以了,那我們該如何調(diào)優(yōu)的呢?
應(yīng)急調(diào)優(yōu)的思路:
針對突然的業(yè)務(wù)辦理卡頓,無法進行正常的業(yè)務(wù)處理!需要立馬解決的場景!
show processlist(查看鏈接session狀態(tài))。
explain(分析查詢計劃),show index from table(分析索引)。
通過執(zhí)行計劃判斷,索引問題(有沒有、合不合理)或者語句本身問題。
show status like '%lock%'; # 查詢鎖狀態(tài)。
SESSION_ID; # 殺掉有問題的session。
常規(guī)調(diào)優(yōu)的思路:
針對業(yè)務(wù)周期性的卡頓,例如在每天10-11點業(yè)務(wù)特別慢,但是還能夠使用,過了這段時間就好了。
查看slowlog,分析slowlog,分析出查詢慢的語句。
按照一定優(yōu)先級,進行一個一個的排查所有慢語句。
分析top sql,進行explain調(diào)試,查看語句執(zhí)行時間。
調(diào)整索引或語句本身。