(一)連接
連接通常來自Web服務器下面列出了一些與連接有關的參數以及該如何設置它們
max_connections
這是Web服務器允許的最大連接數記住每個連接都要使用會話內存(關於會話內存文章後面有涉及)
max_packet_allowed
最大數據包大小通常等於你需要在一個大塊中返回的最大數據集的大小如果你在使用遠程mysqldump那它的值需要更大
aborted_connects
檢查系統狀態的計數器確定其沒有增長如果數量增長說明客戶端連接時遇到了錯誤
thread_cache_size
入站連接會在MySQL中創建一個新的線程因為MySQL中打開和關閉連接都很廉價速度也快它就沒有象其它數據庫如Oracle那麼多持續連接了但線程預先創建並不會節約時間這就是為什麼要MySQL線程緩存的原因了
如果在增長請密切注意創建的線程讓你的線程緩存更大對於或的thread_cache_size內存占用也不多
(二)查詢緩存
MySQL中的緩存查詢包括兩個解析查詢計劃以及返回的數據集如果基礎表數據或結構有變化將會使查詢緩存中的項目無效
query_cache_min_res_unit
MySQL參數中query_cache_min_res_unit查詢緩存中的塊是以這個大小進行分配的使用下面的公式計算查詢緩存的平均大小根據計算結果設置這個變量MySQL就會更有效地使用查詢緩存緩存更多的查詢減少內存的浪費
query_cache_size
這個參數設置查詢緩存的總大小
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的值
(三)臨時表
內存速度是相當快的因此我們希望所有的排序操作都在內存中進行我們可以通過調整查詢讓結果集更小以實現內存排序或將變量設置得更大
tmp_table_size
max_heap_table_size
無論何時在MySQL中創建臨時表它都會使用這兩個變量的最小值作為臨界值除了在磁盤上構建臨時表外還會創建許多會話這些會話會搶占有限制的資源因此最好是調整查詢而不是將這些參數設置得更高同時需要注意的是有BLOB或TEXT字段類型的表將直接寫入磁盤 深入淺出MySQL雙向復制技術
(四)會話內存
MySQL中每個會話都有其自己的內存這個內存就是分配給SQL查詢的內存因此你想讓它變得盡可能大以滿足需要但你不得不平衡同一時間數據庫內一致性會話的數量這裡顯得有點黑色藝術的是MySQL是按需分配緩存的因此你不能只添加它們並乘以會話的數量這樣估算下來比MySQL典型的使用要大得多最佳做法是啟動MySQL連接所有會話然後繼續關注頂級會話的VIRT列mysqld行的數目通常保持相對穩定這就是實際的內存總用量減去所有的靜態MySQL內存區域就得到了實際的所有會話內存然後除以會話的數量就得到平均值
read_buffer_size
緩存連續掃描的塊這個緩存是跨存儲引擎的不只是MyISAM表
sort_buffer_size
執行排序緩存區的大小最好將其設置為MM然後在會話中設置為一個特定的查詢設置更高的值
join_buffer_size
執行聯合查詢分配的緩存區大小將其設置為MM大小然後在每個會話中再單獨按需設置
read_rnd_buffer_size
用於排序和order by操作最好將其設置為M然後在會話中可以將其作為一個會話變量設置為更大的值
(五)慢速查詢日志
慢速查詢日志是MySQL很有用的一個特性
log_slow_queries
MySQL參數中log_slow_queries參數在f文件中設置它將其設置為on默認情況下MySQL會將文件放到數據目錄文件以主機名slowlog的形式命名但你在設置這個選項的時候也可以為其指定一個名字
long_query_time
默認值是秒你可以動態設置它值從到將其設置為on如果數據庫啟動了默認情況下日志將關閉截至和安裝了Google補丁的版本這個選項可以以微秒設置這是一個了不起的功能因為一旦你消除了所有查詢時間超過秒的查詢說明調整非常成功這樣可以幫助你在問題變大之前消除問題SQL
log_queries_not_using_indexes
開啟這個選項是個不錯的主意它真實地記錄了返回所有行的查詢
小結
我們介紹了MySQL參數的五大類設置平時我們一般都很少碰它們在進行數據庫性能調優和故障診斷時這些參數還是非常有用的
From:http://tw.wingwit.com/Article/program/MySQL/201311/29371.html