建議調(diào)整下面幾個關(guān)鍵參數(shù)以獲得較好的性能(可使用本站提供的[my.cnf生成器](http://imysql.com/my_cnf_generator)生成配置文件模板):
1、選擇Percona或MariaDB版本的話,強烈建議啟用thread pool特性,可使得在高并發(fā)的情況下,性能不會發(fā)生大幅下降。此外,還有extra_port功能,非常實用, 關(guān)鍵時刻能救命的。還有另外一個重要特色是 `QUERY_RESPONSE_TIME` 功能,也能使我們對整體的SQL響應(yīng)時間分布有直觀感受;
2、設(shè)置`default-storage-engine=InnoDB`,也就是默認采用InnoDB引擎,強烈建議不要再使用MyISAM引擎了,InnoDB引擎絕對可以滿足99%以上的業(yè)務(wù)場景;
3、調(diào)整`innodb_buffer_pool_size`大小,如果是單實例且絕大多數(shù)是InnoDB引擎表的話,可考慮設(shè)置為物理內(nèi)存的50% ~ 70%左右;
4、根據(jù)實際需要設(shè)置`innodb_flush_log_at_trx_commit`、`sync_binlog`的值。如果要求數(shù)據(jù)不能丟失,那么兩個都設(shè)為1。如果允許丟失一點數(shù)據(jù),則可分別設(shè)為2和10。而如果完全不用care數(shù)據(jù)是否丟失的話(例如在slave上,反正大不了重做一次),則可都設(shè)為0。這三種設(shè)置值導(dǎo)致數(shù)據(jù)庫的性能受到影響程度分別是:高、中、低,也就是第一個會另數(shù)據(jù)庫最慢,最后一個則相反;
5、設(shè)置`innodb_file_per_table = 1`,使用獨立表空間,我實在是想不出來用共享表空間有什么好處了;
6、設(shè)置`innodb_data_file_path = ibdata1:1G:autoextend`,千萬不要用默認的10M,否則在有高并發(fā)事務(wù)時,會受到不小的影響;
7、設(shè)置`innodb_log_file_size=256M`,設(shè)置`innodb_log_files_in_group=2`,基本可滿足90%以上的場景;
8、設(shè)置`long_query_time = 1`,而在5.5版本以上,已經(jīng)可以設(shè)置為小于1了,建議設(shè)置為0.05(50毫秒),記錄那些執(zhí)行較慢的SQL,用于后續(xù)的分析排查;
9、根據(jù)業(yè)務(wù)實際需要,適當調(diào)整`max_connection`(最大連接數(shù))、`max_connection_error`(最大錯誤數(shù),建議設(shè)置為10萬以上,而`open_files_limit`、`innodb_open_files`、`table_open_cache`、`table_definition_cache`這幾個參數(shù)則可設(shè)為約10倍于`max_connection`的大??;
10、常見的誤區(qū)是把`tmp_table_size`和`max_heap_table_size`設(shè)置的比較大,曾經(jīng)見過設(shè)置為1G的,這2個選項是每個連接會話都會分配的,因此不要設(shè)置過大,否則容易導(dǎo)致OOM發(fā)生;其他的一些連接會話級選項例如:`sort_buffer_size`、`join_buffer_size`、`read_buffer_size`、`read_rnd_buffer_size`等,也需要注意不能設(shè)置過大;
11、由于已經(jīng)建議不再使用MyISAM引擎了,因此可以把`key_buffer_size`設(shè)置為32M左右,并且強烈建議關(guān)閉query cache功能;
