日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 运维知识 > 数据库 >内容正文

数据库

MySQL数据库的性能优化总结

發(fā)布時間:2024/9/30 数据库 39 豆豆
生活随笔 收集整理的這篇文章主要介紹了 MySQL数据库的性能优化总结 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

一、MySQL數(shù)據(jù)庫的優(yōu)化目標、基本原則:

1、優(yōu)化目標:

MySQL數(shù)據(jù)庫是常見的兩個瓶頸是CPU和I/O的瓶頸,無論是索引優(yōu)化、還是表結構優(yōu)化,參數(shù)優(yōu)化,最后都可以歸納到這這兩個分類中:

(1)減少 I/O 次數(shù):

I/O是數(shù)據(jù)庫最容易瓶頸的地方,大部分數(shù)據(jù)庫操作中超過90%的時間都是 IO 操作所占用的,減少 IO 次數(shù)是 SQL 優(yōu)化中需要第一優(yōu)先考慮,當然,也是效果最明顯的優(yōu)化手段。

(2)降低 CPU 計算:

除了 IO 瓶頸之外,SQL優(yōu)化中需要考慮的就是 CPU 運算量的優(yōu)化了。order by,group by,distinct … 都是消耗 CPU 的大戶(這些操作基本上都是 CPU 處理內(nèi)存中的數(shù)據(jù)比較運算)。當我們的 IO 優(yōu)化做到一定階段之后,降低 CPU 計算也就成為了我們 SQL 優(yōu)化的重要目標。

2、基本原則:

(1)優(yōu)先優(yōu)化高并發(fā)的 SQL,而不是執(zhí)行頻率低某些“大”SQL:

對于破壞性來說,高并發(fā)的 SQL 總是會比低頻率的 SQL 來得大,因為高并發(fā)的 SQL 一旦出現(xiàn)問題,甚至不會給我們?nèi)魏未⒌臋C會就會將系統(tǒng)壓跨。而對于一些雖然需要消耗大量 IO 而且響應很慢的 SQL,由于頻率低,即使遇到,最多就是讓整個系統(tǒng)響應慢一點,但至少可能撐一會兒,讓我們有緩沖的機會。

(2)從全局出發(fā)優(yōu)化,而不是片面調(diào)整:

SQL 優(yōu)化不能是單獨針對某一個進行,而應充分考慮系統(tǒng)中所有的 SQL,尤其是在通過調(diào)整索引優(yōu)化 SQL 的執(zhí)行計劃的時候,千萬不能顧此失彼,因小失大。

(3)盡可能對每一條運行在數(shù)據(jù)庫中的SQL進行 explain:

優(yōu)化 SQL,需要做到心中有數(shù),知道 SQL 的執(zhí)行計劃才能判斷是否有優(yōu)化余地,才能判斷是否存在執(zhí)行計劃問題。在對數(shù)據(jù)庫中運行的 SQL 進行了一段時間的優(yōu)化之后,很明顯的問題 SQL 可能已經(jīng)很少了,大多都需要去發(fā)掘,這時候就需要進行大量的 explain 操作收集執(zhí)行計劃,并判斷是否需要進行優(yōu)化。

?

二、定位分析SQL語句的性能瓶頸:

1、通過show status 命令了解各種SQL的執(zhí)行效率:

show [session | global] status;

可以根據(jù)需要加上參數(shù)來顯示session級(當前連接,默認)和global級(自數(shù)據(jù)庫上次啟動至今)的統(tǒng)計結果。

show status like 'Com_%';? ---顯示當前連接所有統(tǒng)計參數(shù)的值。

Com_xxx表示每個xxx語句執(zhí)行的次數(shù),通常需要注意的是下面幾個參數(shù):Com_select/Com_insert/Com_update/Com_delete。

2、定位執(zhí)行效率較低的SQL語句:

(1)通過show processlist命令實時查看當前SQL的執(zhí)行情況;

(2)通過慢查詢?nèi)罩径ㄎ怀霈F(xiàn)的問題:《慢查詢?nèi)罩痉治觥?#xff1a;https://blog.csdn.net/a745233700/article/details/84350662

3、通過explain分析慢SQL的執(zhí)行計劃:《explain查看執(zhí)行計劃》:https://blog.csdn.net/a745233700/article/details/84335453

4、通過show profile 分析SQL的具體耗時瓶頸:《使用show profile分析SQL的資源消耗》:https://blog.csdn.net/a745233700/article/details/84345344

通過secect @have_profiling命令能夠看到當前MySQL是否支持profile;

通過show profiles我們能夠更清楚了解SQL執(zhí)行的過程;

通過show profile for query我們能看到執(zhí)行過程中線程的每個狀態(tài)和消耗的時間。

5、更多查看數(shù)據(jù)庫性能的命令可以閱讀這篇文章:https://blog.csdn.net/a745233700/article/details/84708157

?

三、數(shù)據(jù)庫的優(yōu)化方法:

該部分主要總結所有數(shù)據(jù)庫優(yōu)化的方法,每種方法的詳情可以進入對應的文章進行閱讀

1、設計符合范式的數(shù)據(jù)庫:https://blog.csdn.net/a745233700/article/details/80933854

2、選擇合適的存儲引擎:https://blog.csdn.net/a745233700/article/details/80793894

3、SQL表結構、字段優(yōu)化:https://blog.csdn.net/a745233700/article/details/84405087

4、SQL語句優(yōu)化與索引優(yōu)化:https://blog.csdn.net/a745233700/article/details/84455241

5、讀寫分離:主數(shù)據(jù)庫負責寫操作,從數(shù)據(jù)庫負責讀操作。https://blog.csdn.net/a745233700/article/details/85263543

6、分庫分表:垂直切分與水平切分。https://blog.csdn.net/a745233700/article/details/85244436

7、分區(qū):將表的數(shù)據(jù)按照特定的規(guī)則放在不同的分區(qū),提高磁盤的IO效率,提高數(shù)據(jù)庫的性能。https://blog.csdn.net/a745233700/article/details/85250173

8、數(shù)據(jù)庫參數(shù)優(yōu)化:IO參數(shù)、CPU參數(shù):https://blog.csdn.net/a745233700/article/details/114506553

9、硬件配置升級

10、數(shù)據(jù)庫集群

?

總結

以上是生活随笔為你收集整理的MySQL数据库的性能优化总结的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。