《Mysql實例MySQL全面快速優(yōu)化參考》要點:
本文介紹了Mysql實例MySQL全面快速優(yōu)化參考,希望對您有用。如果有疑問,可以聯(lián)系我們。
MYSQL實例1、選擇Percona或MariaDB版本的話,強烈建議啟用thread pool特性,可使得在高并發(fā)的情況下,性能不會發(fā)生大幅下降.此外,還有extra_port功能,非常實用, 關(guān)鍵時刻能救命的.還有另外一個重要特色是 QUERY_RESPONSE_TIME 功能,也能使我們對整體的SQL響應(yīng)時間分布有直觀感受;
MYSQL實例?
MYSQL實例2、設(shè)置default-storage-engine=InnoDB,也就是默認采用InnoDB引擎,強烈建議不要再使用MyISAM引擎了,InnoDB引擎絕對可以滿足99%以上的業(yè)務(wù)場景;
MYSQL實例?
MYSQL實例3、調(diào)整innodb_buffer_pool_size大小,如果是單實例且絕大多數(shù)是InnoDB引擎表的話,可考慮設(shè)置為物理內(nèi)存的50% ~ 70%左右;
MYSQL實例?
MYSQL實例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ù)庫最慢,最后一個則相反;
MYSQL實例?
MYSQL實例5、設(shè)置innodb_file_per_table = 1,使用獨立表空間,我實在是想不出來用共享表空間有什么好處了;
MYSQL實例?
MYSQL實例6、設(shè)置innodb_data_file_path = ibdata1:1G:autoextend,千萬不要用默認的10M,否則在有高并發(fā)事務(wù)時,會受到不小的影響;
MYSQL實例?
MYSQL實例7、設(shè)置innodb_log_file_size=256M,設(shè)置innodb_log_files_in_group=2,基本可滿足90%以上的場景;
MYSQL實例?
MYSQL實例8、設(shè)置long_query_time = 1,而在5.5版本以上,已經(jīng)可以設(shè)置為小于1了,建議設(shè)置為0.05(50毫秒),記錄那些執(zhí)行較慢的SQL,用于后續(xù)的分析排查;
MYSQL實例?
MYSQL實例9、根據(jù)業(yè)務(wù)實際需要,適當(dāng)調(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的大小;
MYSQL實例?
MYSQL實例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è)置過大;
MYSQL實例?
MYSQL實例11、由于已經(jīng)建議不再使用MyISAM引擎了,因此可以把key_buffer_size設(shè)置為32M左右,并且強烈建議關(guān)閉query cache功能;
轉(zhuǎn)載請注明本頁網(wǎng)址:
http://www.fzlkiss.com/jiaocheng/5719.html