學會設定五大類MySQL參數

來源:互聯網
上載者:User

(一)串連

  串連通常來自Web伺服器,下面列出了一些與串連有關的參數,以及該如何設定它們。

  1、max_connections

  這是Web伺服器允許的最大串連數,記住每個串連都要使用會話記憶體(關於會話記憶體,文章後面有涉及)。

  2、max_packet_allowed

  最大資料包大小,通常等於你需要在一個大塊中返回的最大資料集的大小,如果你在使用遠程mysqldump,那它的值需要更大。

  3、aborted_connects

  檢查系統狀態的計數器,確定其沒有增長,如果數量增長說明用戶端串連時遇到了錯誤。

  4、thread_cache_size

  入站串連會在MySQL中建立一個新的線程,因為MySQL中開啟和關閉串連都很廉價,速度也快,它就沒有象其它資料庫,如Oracle那麼多持續串連了,但線程預先建立並不會節約時間,這就是為什麼要MySQL線程緩衝的原因了。

  如果在增長請密切注意建立的線程,讓你的線程緩衝更大,對於2550或100的thread_cache_size,記憶體佔用也不多。

  (二)查詢快取
(三)暫存資料表

  記憶體速度是相當快的,因此我們希望所有的排序操作都在記憶體中進行,我們可以通過調整查詢讓結果集更小以實現記憶體排序,或將變數設定得更大。

  tmp_table_size

  max_heap_table_size

  無論何時在MySQL中建立暫存資料表,它都會使用這兩個變數的最小值作為臨界值,除了在磁碟上構建暫存資料表外,還會建立許多會話,這些會話會搶佔有限制的資源,因此最好是調整查詢而不是將這些參數設定得更高,同時,需要注意的是有BLOB或TEXT欄位類型的表將直接寫入磁碟。 深入淺出MySQL雙向複製技術

  (四)會話記憶體

  MySQL中每個會話都有其自己的記憶體,這個記憶體就是分配給SQL查詢的記憶體,因此你想讓它變得儘可能大以滿足需要。但你不得不平衡同一時間資料庫內一致性會話的數量。這裡顯得有點黑色藝術的是MySQL是按需分配緩衝的,因此,你不能只添加它們並乘以會話的數量,這樣估算下來比MySQL典型的使用要大得多。最佳做法是啟動MySQL,串連所有會話,然後繼續關注頂級會話的VIRT列,mysqld行的數目通常保持相對穩定,這就是實際的記憶體總用量,減去所有的靜態MySQL記憶體地區,就得到了實際的所有會話記憶體,然後除以會話的數量就得到平均值。

  1、read_buffer_size

  緩衝連續掃描的塊,這個緩衝是跨儲存引擎的,不只是MyISAM表。

  2、sort_buffer_size

  執行排序緩衝區的大小,最好將其設定為1M-2M,然後在會話中設定,為一個特定的查詢設定更高的值。

  3、join_buffer_size

  執行聯集查詢分配的緩衝區大小,將其設定為1M-2M大小,然後在每個會話中再單獨按需設定。

  4、read_rnd_buffer_size

  用於排序和order by操作,最好將其設定為1M,然後在會話中可以將其作為一個會話變數設定為更大的值。

  (五)慢速查詢日誌

  慢速查詢日誌是MySQL很有用的一個特性。

  1、log_slow_queries

  MySQL參數中log_slow_queries參數在my.cnf檔案中設定它,將其設定為on,預設情況下,MySQL會將檔案放到資料目錄,檔案以“主機名稱-slow.log”的形式命名,但你在設定這個選項的時候也可以為其指定一個名字。

  2、long_query_time

  預設值是10秒,你可以動態設定它,值從1到將其設定為on,如果資料庫啟動了,預設情況下,日誌將關閉。截至5.1.21和安裝了Google補丁的版本,這個選項可以以微秒設定,這是一個了不起的功能,因為一旦你消除了所有查詢時間超過1秒的查詢,說明調整非常成功,這樣可以協助你在問題變大之前消除問題SQL。

  3、log_queries_not_using_indexes

  開啟這個選項是個不錯的主意,它真實地記錄了返回所有行的查詢。

  小結

  我們介紹了MySQL參數的五大類設定,平時我們一般都很少碰它們,在進行資料庫效能調優和故障診斷時這些參數還是非常有用的。

  MySQL中的緩衝查詢包括兩個解析查詢計劃,以及返回的資料集,如果基礎資料表資料或結構有變化,將會使查詢快取中的項目無效。

  1、query_cache_min_res_unit

  MySQL參數中query_cache_min_res_unit查詢快取中的塊是以這個大小進行分配的,使用下面的公式計算查詢快取的平均大小,根據計算結果設定這個變數,MySQL就會更有效地使用查詢快取,緩衝更多的查詢,減少記憶體的浪費。

  2、query_cache_size

  這個參數設定查詢快取的總大小。

  3、query_cache_limit

  這個參數告訴MySQL丟掉大於這個大小的查詢,一般大型查詢還是比較少見的,如運行一個批處理執行一個大型報表的統計,因此那些大型結果集不應該填滿查詢快取。

  qcache hit ratio = qcache_hits / (qcache_hits + com_select)

  使用

  SQL> show status like 'qcache%';

  SQL> show status like 'com_%';

  找到這些變數。

  average query size = (query_cache_size - qcache_free_memory)/qcache_queries_in_cache

  使用

  SQL> show variables like 'query%';

  qcache_* status variables you can get with:

  SQL> show status like 'qcache%';

  擷取query_cache_size的值。

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.