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