以下主要是對MySQL 性能影響關系緊密的五大配置參數的介紹。
一、 連接
連接通常來自Web 服務器,下面列出了一些與連接有關的參數,以及該如何設置它們。
(一)、 max_connections
這是Web服務器允許的最大連接數,記住每個連接都要使用會話內存(關於會話內存,文章后面有涉及)。
1. 查看max_connections參數的值
SQL>show variables like "max_connections";
2. 調整max_connections參數的值
1)、臨時有效修改辦法:SQL>set global max_connections = 200;
修改完成后實時生效,無需重啟MySQL。但是下次重啟后這個設置會失效
2)、永久有效修改辦法:修改mysql的ini配置文件my.ini或/etc/my.cnf
找到mysqld塊,修改或者添加下面的設置:max_connections=200
(二)、 max_allowed_packet
最大數據包大小,通常等於你需要在一個大塊中返回的最大數據集的大小,如果你在使用遠程mysqldump,那它的值需要更大。
1. 查看max_allowed_packet參數的值
SQL>show variables like "max _allowed_packet";
2. 調整max_allowed_packet參數的值
1)、臨時有效修改方法:SQL>SET GLOBAL max_allowed_packet = 2*1024*1024*16
2)、永久有效修改方法:修改mysql的ini配置文件my.ini或/etc/my.cnf
[mysqld]
max_allowed_packet = 1M (如果沒有增加一行),保存,重起MySQL服務。
(三)、 aborted_connects
檢查系統狀態的計數器,確定其沒有增長,如果數量增長說明客戶端連接時遇到了錯誤。
1. 查看aborted_connects狀態的值
SQL>show status like "aborted_connects";
2. 查看哪些用戶從哪些地方登陸(異常的需要剔除)
mysql> select host,user from mysql.user;
3. 清空狀態變量
mysql> flush status;
(四)、 thread_cache_size
入站連接會在MySQL中創建一個新的線程,因為MySQL中打開和關閉連接都很廉價,速度也快,它就沒有象其它數據庫,如Oracle那么多持續連接了,但線程預先創建並不會節約時間,這就是為什么要MySQL線程緩存的原因了。
如果在增長請密切注意創建的線程,讓你的線程緩存更大,對於2550或100的thread_cache_size,內存占用也不多。
1. 查看thread_cache_size狀態的值
SQL>show global status like 'thread_cache_size';
2. 修改thread_cache_size狀態的值
1)、臨時有效修改方法:mysql> set global thread_cache_size=16
2)、永久有效修改方法:修改mysql的ini配置文件my.ini或/etc/my.cnf
[mysqld]
thread_concurrency = 16
3. 設置參數值基本規則
機器物理內存 |
thread_concurrency設置值 |
1G |
8 |
2G |
16 |
3G |
32 |
>3G |
64 |
二、 查詢緩存
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
1. 修改tmp_table_size狀態的值
1)、臨時有效修改方法:
SET GLOBAL tmp_table_size=2147483648; //2G
SET GLOBAL max_heap_table_size=2147483648; //2G
2)、永久有效修改方法:修改mysql的ini配置文件my.ini或/etc/my.cnf
[mysqld]
max_heap_table_size = 2048M
tmp_table_size = 2048M
(二)、 max_heap_table_size
無論何時在MySQL中創建臨時表,它都會使用這兩個變量的最小值作為臨界值,除了在磁盤上構建臨時表外,還會創建許多會話,這些會話會搶占有限制的資源,因此最好是調整查詢而不是將這些參數設置得更高,同時,需要注意的是有BLOB或TEXT字段類型的表將直接寫入磁盤。
四、 會話內存
MySQL中每個會話都有其自己的內存,這個內存就是分配給SQL 查詢的內存,因此你想讓它變得盡可能大以滿足需要。但你不得不平衡同一時間數據庫內一致性會話的數量。這里顯得有點黑色藝術的是MySQL是按需分配緩存的,因此,你不能只添加它們並乘以會話的數量,這樣估算下來比MySQL典型的使用要大得多。
最佳做法是啟動MySQL,連接所有會話,然后繼續關注頂級會話的VIRT列,mysqld行的數目通常保持相對穩定,這就是實際的內存總用量,減去所有的靜態MySQL內存區域,就得到了實際的所有會話內存,然后除以會話的數量就得到平均值。
(一)、 read_buffer_size
read_buffer_size:是MySQL讀入緩沖區大小。對表進行順序掃描的請求將分配一個讀入緩沖區,MySQL會為它分配一段內存緩沖區。read_buffer_size變量控制這一緩沖區的大小。如果對表的順序掃描請求非常頻繁,並且你認為頻繁掃描進行得太慢,可以通過增加該變量值以及內存緩沖區大小提高其性能
緩存連續掃描的塊,這個緩存是跨存儲引擎的,不只是MyISAM表。
修改案例:db服務器內存16G,8核,dell的pc服務器。qps: 200個左右 ;tps: 1個左右 一分鍾50幾個
sort_buffer_size = 32M 大了, 8M即可
read_buffer_size = 32M 大了,8M即可
join_buffer_size = 32M 大了,8M即可
read_rnd_buffer_size = 16M 大了,8M即可
table_open_cache = 512 小了,建議改成2048
max_allowed_packet = 5M 小了,建議改成16M
tmp_table_size=64M 小了,建議改成2G
innodb_buffer_pool_size = 3000M 小了,改成db服務器總內存的60% 到80%
innodb_additional_mem_pool_size = 20M 小了,改成128M
(二)、 sort_buffer_size
執行排序緩存區的大小,最好將其設置為1M-2M,然后在會話中設置,為一個特定的查詢設置更高的值。
(三)、 join_buffer_size
執行聯合查詢分配的緩存區大小,將其設置為1M-2M大小,然后在每個會話中再單獨按需設置。
(四)、 read_rnd_buffer_size
用於排序和order by操作,最好將其設置為1M,然后在會話中可以將其作為一個會話變量設置為更大的值。
五、 慢速查詢日志
慢速查詢日志是MySQL很有用的一個特性。
(一)、 log_slow_queries
MySQL參數中log_slow_queries參數在my.cnf文件中設置它,將其設置為on,默認情況下,MySQL會將文件放到數據目錄,文件以“主機名-slow.log”的形式命名,但你在設置這個選項的時候也可以為其指定一個名字。
在線修改設置:SQL>set global log_slow_queries = on; # 開啟慢日志
查看存放日志的形式
mysql> show variables like 'log_output';
Variable_name |
Value |
Log_output |
FILE |
這個FILE是指以文件的形式存放.
如果是TABLE就是存放到系統表中. mysql.slow_log表中.
使用set global log_output='table';變量更改
mysqldumpslow命令查看慢日志.
參數說明: -s,是表示按照何種方式排序,c、t、l、r分別是按照記錄次數、時間、查詢時間、返回的記錄數來排序(從大到小),ac、at、al、ar表示相應的倒敘. -t, 是top n的意思,即為返回前面多少條數據. -g,后邊可以寫一個正則匹配模式,大小寫不敏感.
mysqldumpslow -s c -t 10 host-slow.log
列出返回記錄集最多的10個sql語句
mysqldumpslow -s r -t 10 host-slow.log
按照時間返回前10條里面含有左連接的sql語句
mysqldumpslow -s t -t 10 -g "left join" host-slow.log
(二)、 long_query_time
默認值是10秒,你可以動態設置它,值從1到將其設置為on,如果數據庫啟動了,默認情況下,日志將關閉。截至5.1.21和安裝了Google 補丁的版本,這個選項可以以微秒設置,這是一個了不起的功能,因為一旦你消除了所有查詢時間超過1秒的查詢,說明調整非常成功,這樣可以幫助 你在問題變大之前消除問題SQL。
set [session|global] long_query_time =0.2 # 設置時間.精確的毫秒
(三)、 log_queries_not_using_indexes
開啟這個選項是個不錯的主意,它真實地記錄了返回所有行的查詢。
set global log_queries_not_using_indexes = on; # 設置無索引的查詢
小結
我們介紹了MySQL參數的五大類設置,平時我們一般都很少碰它們,在進行MySQL性能調優和故障診斷時這些參數還是非常有用的。