亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 數據庫 > MySQL > 正文

Mysql性能優化方案分享

2024-07-24 13:09:00
字體:
來源:轉載
供稿:網友
這篇文章主要為大家分享了Mysql性能優化方案,幫助大家進行Mysql性能優化,感興趣的小伙伴們可以參考一下
 

網上有不少mysql 性能優化方案,不過,mysql的優化同sql server相比,更為麻煩,同樣的設置,在不同的環境下 ,由于內存,訪問量,讀寫頻率,數據差異等等情況,可能會出現不同的結果,因此簡單地根據某個給出方案來配置mysql是行不通的,最好能使用status信息對mysql進行具體的優化。

mysql> show global status;

可以列出MySQL服務器運行各種狀態值,另外,查詢MySQL服務器配置信息語句:
mysql> show variables;

一、慢查詢

mysql> show variables like ‘%slow%‘;+——————+——-+| Variable_name     | Value |+——————+——-+| log_slow_queries | ON     || slow_launch_time | 2      |+——————+——-+mysql> show global status like ‘%slow%‘;+———————+——-+| Variable_name        | Value |+———————+——-+| Slow_launch_threads | 0      || Slow_queries         | 4148 |+———————+——-+

配置中打開了記錄慢查詢,執行時間超過2秒的即為慢查詢,系統顯示有4148個慢查詢,你可以分析慢查詢日志,找出有問題的SQL語句,慢查詢時間不宜設置過長,否則意義不大,最好在5秒以內,如果你需要微秒級別的慢查詢,可以考慮給MySQL打補?。?span style="line-height: 21.6px; font-size: 12px; color: rgb(51, 51, 51);">http://www.percona.com/docs/wiki/release:start,記得找對應的版本。
打開慢查詢日志可能會對系統性能有一點點影響,如果你的MySQL是主-從結構,可以考慮打開其中一臺從服務器的慢查詢日志,這樣既可以監控慢查詢,對系統性能影響又小。

二、連接數
經常會遇見”MySQL: ERROR 1040: Too many connections”的情況,一種是訪問量確實很高,MySQL服務器抗不住,這個時候就要考慮增加從服務器分散讀壓力,另外一種情況是MySQL配置文件中max_connections值過小:

mysql> show variables like ‘max_connections‘;+—————–+——-+| Variable_name    | Value |+—————–+——-+| max_connections | 256   |+—————–+——-+

這臺MySQL服務器最大連接數是256,然后查詢一下服務器響應的最大連接數:
mysql> show global status like ‘Max_used_connections‘;
MySQL服務器過去的最大連接數是245,沒有達到服務器連接數上限256,應該沒有出現1040錯誤,比較理想的設置是
Max_used_connections / max_connections * 100% ≈ 85%
最大連接數占上限連接數的85%左右,如果發現比例在10%以下,MySQL服務器連接數上限設置的過高了。
三、Key_buffer_size
key_buffer_size是對MyISAM表性能影響最大的一個參數,下面一臺以MyISAM為主要存儲引擎服務器的配置:

mysql> show variables like ‘key_buffer_size‘;+—————–+————+| Variable_name    | Value       |+—————–+————+| key_buffer_size | 536870912 |+—————–+————+

分配了512MB內存給key_buffer_size,我們再看一下key_buffer_size的使用情況:

mysql> show global status like ‘key_read%‘;+————————+————-+| Variable_name           | Value        |+————————+————-+| Key_read_requests       | 27813678764 || Key_reads               | 6798830      |+————————+————-+

一共有27813678764個索引讀取請求,有6798830個請求在內存中沒有找到直接從硬盤讀取索引,計算索引未命中緩存的概率:
key_cache_miss_rate = Key_reads / Key_read_requests * 100%
比如上面的數據,key_cache_miss_rate為0.0244%,4000個索引讀取請求才有一個直接讀硬盤,已經很BT了,key_cache_miss_rate在0.1%以下都很好(每1000個請求有一個直接讀硬盤),如果key_cache_miss_rate在0.01%以下的話,key_buffer_size分配的過多,可以適當減少。
MySQL服務器還提供了key_blocks_*參數:

mysql> show global status like ‘key_blocks_u%‘;+————————+————-+| Variable_name           | Value        |+————————+————-+| Key_blocks_unused       | 0            || Key_blocks_used         | 413543       |+————————+————-+

Key_blocks_unused表示未使用的緩存簇(blocks)數,Key_blocks_used表示曾經用到的最大的blocks數,比如這臺服務器,所有的緩存都用到了,要么增加key_buffer_size,要么就是過渡索引了,把緩存占滿了。比較理想的設置:
Key_blocks_used / (Key_blocks_unused + Key_blocks_used) * 100% ≈ 80%
四、臨時表

mysql> show global status like ‘created_tmp%‘;+————————-+———+| Variable_name            | Value    |+————————-+———+| Created_tmp_disk_tables | 21197    || Created_tmp_files        | 58       || Created_tmp_tables       | 1771587 |+————————-+———+

每次創建臨時表,Created_tmp_tables增加,如果是在磁盤上創建臨時表,Created_tmp_disk_tables也增加,Created_tmp_files表示MySQL服務創建的臨時文件文件數,比較理想的配置是:
Created_tmp_disk_tables / Created_tmp_tables * 100% <= 25%比如上面的服務器Created_tmp_disk_tables / Created_tmp_tables * 100% = 1.20%,應該相當好了。我們再看一下MySQL服務器對臨時表的配置:

mysql> show variables where Variable_name in (‘tmp_table_size‘, ‘max_heap_table_size‘);+———————+———–+| Variable_name        | Value      |+———————+———–+| max_heap_table_size | 268435456 || tmp_table_size       | 536870912 |+———————+———–+

只有256MB以下的臨時表才能全部放內存,超過的就會用到硬盤臨時表。
五、Open Table情況

mysql> show global status like ‘open%tables%‘;+—————+——-+| Variable_name | Value |+—————+——-+| Open_tables    | 919    || Opened_tables | 1951  |+—————+——-+

Open_tables表示打開表的數量,Opened_tables表示打開過的表數量,如果Opened_tables數量過大,說明配置中table_cache(5.1.3之后這個值叫做table_open_cache)值可能太小,我們查詢一下服務器table_cache值:

mysql> show variables like ‘table_cache‘;+—————+——-+| Variable_name | Value |+—————+——-+| table_cache    | 2048  |+—————+——-+

比較合適的值為:
Open_tables / Opened_tables * 100% >= 85%
Open_tables / table_cache * 100% <= 95%

六、進程使用情況

mysql> show global status like ‘Thread%‘;+——————-+——-+| Variable_name      | Value |+——————-+——-+| Threads_cached     | 46     || Threads_connected | 2      || Threads_created    | 570    || Threads_running    | 1      |+——————-+——-+

如果我們在MySQL服務器配置文件中設置了thread_cache_size,當客戶端斷開之后,服務器處理此客戶的線程將會緩存起來以響應下一個客戶而不是銷毀(前提是緩存數未達上限)。Threads_created表示創建過的線程數,如果發現Threads_created值過大的話,表明MySQL服務器一直在創建線程,這也是比較耗資源,可以適當增加配置文件中thread_cache_size值,查詢服務器thread_cache_size配置:

mysql> show variables like ‘thread_cache_size‘;+——————-+——-+| Variable_name      | Value |+——————-+——-+| thread_cache_size | 64     |+——————-+——-+

示例中的服務器還是挺健康的。
七、查詢緩存(query cache)

mysql> show global status like ‘qcache%‘;+————————-+———–+| Variable_name            | Value      |+————————-+———–+| Qcache_free_blocks       | 22756      || Qcache_free_memory       | 76764704  || Qcache_hits              | 213028692 || Qcache_inserts           | 208894227 || Qcache_lowmem_prunes     | 4010916    || Qcache_not_cached        | 13385031  || Qcache_queries_in_cache | 43560      || Qcache_total_blocks      | 111212     |+————————-+———–+

MySQL查詢緩存變量解釋:
Qcache_free_blocks:緩存中相鄰內存塊的個數。數目大說明可能有碎片。FLUSH QUERY CACHE會對緩存中的碎片進行整理,從而得到一個空閑塊。
Qcache_free_memory:緩存中的空閑內存。
Qcache_hits:每次查詢在緩存中命中時就增大
Qcache_inserts:每次插入一個查詢時就增大。命中次數除以插入次數就是不中比率。
Qcache_lowmem_prunes:緩存出現內存不足并且必須要進行清理以便為更多查詢提供空間的次數。這個數字最好長時間來看;如果這個數字在不斷增長,就表示可能碎片非常嚴重,或者內存很少。(上面的 free_blocks和free_memory可以告訴您屬于哪種情況)
Qcache_not_cached:不適合進行緩存的查詢的數量,通常是由于這些查詢不是 SELECT 語句或者用了now()之類的函數。
Qcache_queries_in_cache:當前緩存的查詢(和響應)的數量。
Qcache_total_blocks:緩存中塊的數量。
我們再查詢一下服務器關于query_cache的配置:

mysql> show variables like ‘query_cache%‘;+——————————+———–+| Variable_name                 | Value      |+——————————+———–+| query_cache_limit             | 2097152    || query_cache_min_res_unit      | 4096       || query_cache_size              | 203423744 || query_cache_type              | ON         || query_cache_wlock_invalidate | OFF        |+——————————+———–+

各字段的解釋:
query_cache_limit:超過此大小的查詢將不緩存
query_cache_min_res_unit:緩存塊的最小大小
query_cache_size:查詢緩存大小
query_cache_type:緩存類型,決定緩存什么樣的查詢,示例中表示不緩存 select sql_no_cache 查詢
query_cache_wlock_invalidate:當有其他客戶端正在對MyISAM表進行寫操作時,如果查詢在query cache中,是否返回cache結果還是等寫操作完成再讀表獲取結果。
query_cache_min_res_unit的配置是一柄”雙刃劍”,默認是4KB,設置值大對大數據查詢有好處,但如果你的查詢都是小數據查詢,就容易造成內存碎片和浪費。
查詢緩存碎片率 = Qcache_free_blocks / Qcache_total_blocks * 100%
如果查詢緩存碎片率超過20%,可以用FLUSH QUERY CACHE整理緩存碎片,或者試試減小query_cache_min_res_unit,如果你的查詢都是小數據量的話。
查詢緩存利用率 = (query_cache_size – Qcache_free_memory) / query_cache_size * 100%
查詢緩存利用率在25%以下的話說明query_cache_size設置的過大,可適當減??;查詢緩存利用率在80%以上而且Qcache_lowmem_prunes > 50的話說明query_cache_size可能有點小,要不就是碎片太多。
查詢緩存命中率 = (Qcache_hits – Qcache_inserts) / Qcache_hits * 100%
示例服務器 查詢緩存碎片率 = 20.46%,查詢緩存利用率 = 62.26%,查詢緩存命中率 = 1.94%,命中率很差,可能寫操作比較頻繁吧,而且可能有些碎片。
八、排序使用情況

mysql> show global status like ‘sort%‘;+——————-+————+| Variable_name      | Value       |+——————-+————+| Sort_merge_passes | 29          || Sort_range         | 37432840    || Sort_rows          | 9178691532 || Sort_scan          | 1860569     |+——————-+————+

Sort_merge_passes 包括兩步。MySQL 首先會嘗試在內存中做排序,使用的內存大小由系統變量 Sort_buffer_size 決定,如果它的大小不夠把所有的記錄都讀到內存中,MySQL 就會把每次在內存中排序的結果存到臨時文件中,等 MySQL 找到所有記錄之后,再把臨時文件中的記錄做一次排序。這再次排序就會增加 Sort_merge_passes。實際上,MySQL 會用另一個臨時文件來存再次排序的結果,所以通常會看到 Sort_merge_passes 增加的數值是建臨時文件數的兩倍。因為用到了臨時文件,所以速度可能會比較慢,增加 Sort_buffer_size 會減少 Sort_merge_passes 和 創建臨時文件的次數。但盲目的增加 Sort_buffer_size 并不一定能提高速度,見 How fast can you sort data with MySQL?(另外,增加read_rnd_buffer_size(3.2.3是record_rnd_buffer_size)的值對排序的操作也有一點的好處

九、文件打開數(open_files)

mysql> show global status like ‘open_files‘;+—————+——-+| Variable_name | Value |+—————+——-+| Open_files     | 1410  |+—————+——-+mysql> show variables like ‘open_files_limit‘;+——————+——-+| Variable_name     | Value |+——————+——-+| open_files_limit | 4590  |+——————+——-+

比較合適的設置:Open_files / open_files_limit * 100% <= 75%
十、表鎖情況

mysql> show global status like ‘table_locks%‘;+———————–+———–+| Variable_name          | Value      |+———————–+———–+| Table_locks_immediate | 490206328 || Table_locks_waited     | 2084912    |+———————–+———–+

Table_locks_immediate表示立即釋放表鎖數,Table_locks_waited表示需要等待的表鎖數,如果Table_locks_immediate / Table_locks_waited > 5000,最好采用InnoDB引擎,因為InnoDB是行鎖而MyISAM是表鎖,對于高并發寫入的應用InnoDB效果會好些。示例中的服務器Table_locks_immediate / Table_locks_waited = 235,MyISAM就足夠了。
十一、表掃描情況

mysql> show global status like ‘handler_read%‘;+———————–+————-+| Variable_name          | Value        |+———————–+————-+| Handler_read_first     | 5803750      || Handler_read_key       | 6049319850  || Handler_read_next      | 94440908210 || Handler_read_prev      | 34822001724 || Handler_read_rnd       | 405482605    || Handler_read_rnd_next | 18912877839 |+———————–+————-+

調出服務器完成的查詢請求次數:

mysql> show global status like ‘com_select‘;+—————+———–+| Variable_name | Value      |+—————+———–+| Com_select     | 222693559 |+—————+———–+

計算表掃描率:
表掃描率 = Handler_read_rnd_next / Com_select
如果表掃描率超過4000,說明進行了太多表掃描,很有可能索引沒有建好,增加read_buffer_size值會有一些好處,但最好不要超過8MB。

以上就是本文的全部內容,希望對大家的學習有所幫助。



注:相關教程知識閱讀請移步到MYSQL教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
久久最新资源网| 国产欧美在线视频| 久久精品99无色码中文字幕| 精品美女永久免费视频| 亚洲美女av网站| 91色琪琪电影亚洲精品久久| 日本人成精品视频在线| 国产精品福利在线| 欧美精品video| 亚洲欧美日韩爽爽影院| 欧美亚洲成人网| 久久免费视频这里只有精品| 国产精品91视频| 日韩国产精品亚洲а∨天堂免| 136fldh精品导航福利| 九九久久久久久久久激情| 日韩亚洲成人av在线| 欧美肥老太性生活视频| 国产成人免费91av在线| 97av在线影院| 欧美情侣性视频| 日韩久久精品电影| 久久精品久久久久久| 97国产在线视频| 中文字幕日韩av综合精品| 国产在线视频一区| 97av在线影院| 国产日韩精品在线观看| 欧美人在线视频| 色综合视频网站| 97在线精品视频| 在线观看国产成人av片| 538国产精品一区二区在线| 91免费精品视频| 精品欧美激情精品一区| 亚洲国产高清福利视频| 欧美日韩一二三四五区| 久久免费成人精品视频| 久久成人精品一区二区三区| 久久久中精品2020中文| 中文字幕av一区中文字幕天堂| 欧美激情第6页| 久久久久久久影院| 欧美日韩中文字幕综合视频| 欧美精品一二区| 国产激情综合五月久久| 日韩一级裸体免费视频| 狠狠躁夜夜躁人人躁婷婷91| 欧美国产在线视频| 亚洲欧美第一页| 国产97在线播放| 欧美电影在线观看网站| 国产欧美日韩免费| 国产日韩精品在线播放| 国产精品r级在线| 久久久精品一区二区三区| 性欧美激情精品| 欧美一级免费视频| 国产精品高潮呻吟久久av黑人| 97精品伊人久久久大香线蕉| 岛国视频午夜一区免费在线观看| 色偷偷av一区二区三区| 久久色精品视频| 亚洲国产精品免费| 欧美精品久久久久久久久| 国模精品视频一区二区| 国产精品自产拍高潮在线观看| 国产精品999999| 少妇精69xxtheporn| 九九精品视频在线观看| 欧美日韩在线观看视频小说| 日韩免费在线电影| 在线精品国产成人综合| 亚洲高清一区二| 伊人久久综合97精品| 国产97在线亚洲| 成人观看高清在线观看免费| 久久久综合免费视频| 九九视频直播综合网| 亚洲欧洲日产国码av系列天堂| 激情亚洲一区二区三区四区| 日韩欧美国产一区二区| 亚洲视频日韩精品| 日韩黄色av网站| 精品亚洲va在线va天堂资源站| 麻豆乱码国产一区二区三区| 国产99视频在线观看| 亚洲国产精品va在线| 精品亚洲一区二区三区在线播放| 国产精品美女www爽爽爽视频| 97国产精品久久| 亚洲男人天堂九九视频| 韩国三级日本三级少妇99| 亚洲黄色片网站| 国产精品都在这里| 久久中文久久字幕| 国产一区二区在线免费视频| 日本精品一区二区三区在线播放视频| 欧美精品中文字幕一区| 欧美日韩中文字幕综合视频| 亚洲男人天堂2023| 这里只有精品在线播放| 欧美午夜激情视频| 国产不卡在线观看| 成人免费观看49www在线观看| 国产精品人成电影在线观看| 91亚洲国产成人精品性色| 日韩在线高清视频| 久久天天躁夜夜躁狠狠躁2022| 日韩风俗一区 二区| 亚洲国产成人爱av在线播放| 欧美激情奇米色| 中文字幕亚洲色图| 亚洲最大福利网站| 国产在线视频不卡| 欧美在线观看一区二区三区| 国产丝袜一区二区三区免费视频| 在线成人中文字幕| 国产日韩欧美夫妻视频在线观看| 国产精品专区h在线观看| 国产精品尤物福利片在线观看| 亚洲美女性生活视频| 亚洲国产精品字幕| 欧美激情综合色| 国产成人精品最新| 精品国产一区二区三区在线观看| 国产一区二区三区四区福利| 欧美日韩免费网站| 久久青草精品视频免费观看| 国产精品成人在线| 久久久久久久久久婷婷| 成人在线精品视频| 国产一区二区三区在线| 久久天天躁狠狠躁夜夜av| 久久理论片午夜琪琪电影网| 日韩美女中文字幕| 日韩精品久久久久久久玫瑰园| 国产91精品网站| 欧美二区乱c黑人| 欧美日韩视频免费播放| 俺去亚洲欧洲欧美日韩| 日韩电影第一页| 国产精品久久国产精品99gif| 国产精品免费一区豆花| 欧美性jizz18性欧美| 亚洲精品久久久久久久久久久久| 国产在线日韩在线| 成人www视频在线观看| 国产精品第10页| 乱亲女秽乱长久久久| 国产91精品高潮白浆喷水| 国产成人精品最新| 国产精品美女在线| 97在线观看视频国产| 国产精品久久久av久久久| 78m国产成人精品视频| 在线观看欧美成人| 黄色91在线观看| 国产成人+综合亚洲+天堂| 一区二区三区国产视频| 亚洲a∨日韩av高清在线观看| 欧美一区二区三区免费观看| 欧美在线视频在线播放完整版免费观看| 欧美亚洲国产日韩2020|