程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 數據庫知識 >> MYSQL數據庫 >> MySQL綜合教程 >> 影響MySQL機能的五年夜設置裝備擺設參數

影響MySQL機能的五年夜設置裝備擺設參數

編輯:MySQL綜合教程

影響MySQL機能的五年夜設置裝備擺設參數。本站提示廣大學習愛好者:(影響MySQL機能的五年夜設置裝備擺設參數)文章只能為提供參考,不一定能成為您想要的結果。以下是影響MySQL機能的五年夜設置裝備擺設參數正文


以下的文章重要是對MySQL機能影響關系慎密的五年夜設置裝備擺設參數的引見,我頭幾天在相干網站看見對MySQL機能影響關系慎密的五年夜設置裝備擺設參數的材料,認為挺好,就拿出來供年夜家分享,望你能有所收成。

(一)銜接

銜接平日來自Web辦事器,上面列出了一些與銜接有關的參數,和該若何設置它們。

1、max_connections

這是Web辦事器許可的最年夜銜接數,記住每一個銜接都要應用會話內存(關於會話內存,文章前面有觸及)。

2、max_packet_allowed

最年夜數據包年夜小,平日等於你須要在一個年夜塊中前往的最年夜數據集的年夜小,假如你在應用長途mysqldump,那它的值須要更年夜。

3、aborted_connects

檢討體系狀況的計數器,肯定其沒有增加,假如數目增加解釋客戶端銜接時碰到了毛病。

4、thread_cache_size

入站銜接會在MySQL中創立一個新的線程,由於MySQL中翻開和封閉銜接都很便宜,速度也快,它就沒有象其它數據庫,如Oracle那末多連續銜接了,但線程事後創立其實不會勤儉時光,這就是為何要MySQL線程緩存的緣由了。

假如在增加請親密留意創立的線程,讓你的線程緩存更年夜,關於2550或100的thread_cache_size,內存占用也不多。

(二)查詢緩存

(三)暫時表

內存速度是相當快的,是以我們願望一切的排序操作都在內存中停止,我們可以經由過程調劑查詢讓成果集更小以完成內存排序,或將變量設置得更年夜。

tmp_table_size

max_heap_table_size

不管什麼時候在MySQL中創立暫時表,它都邑應用這兩個變量的最小值作為臨界值,除在磁盤上構建暫時表外,還會創立很多會話,這些會話會搶占領 限制的資本,是以最好是調劑查詢而不是將這些參數設置得更高,同時,須要留意的是有BLOB或TEXT字段類型的表將直接寫入磁盤。 深刻淺出MySQL雙向復制技巧

(四)會話內存

MySQL中每一個會話都有其本身的內存,這個內存就是分派給SQL查詢的內存,是以你想讓它變得盡量年夜以知足須要。但你不能不均衡統一時光數 據庫內分歧性會話的數目。這裡顯得有點黑色藝術的是MySQL是按需分派緩存的,是以,你不克不及只添加它們並乘以會話的數目,如許預算上去比MySQL典范 的應用要年夜很多。

最好做法是啟動MySQL,銜接一切會話,然後持續存眷頂級會話的VIRT列,mysqld行的數量平日堅持絕對穩固,這就是現實的內存 總用量,減去一切的靜態MySQL內存區域,就獲得了現實的一切會話內存,然後除以會話的數目就獲得均勻值。

1、read_buffer_size

緩存持續掃描的塊,這個緩存是跨存儲引擎的,不只是MyISAM表。

2、sort_buffer_size

履行排序緩存區的年夜小,最好將其設置為1M-2M,然後在會話中設置,為一個特定的查詢設置更高的值。

3、join_buffer_size

履行結合查詢分派的緩存區年夜小,將其設置為1M-2M年夜小,然後在每一個會話中再零丁按需設置。

4、read_rnd_buffer_size

用於排序和order by操作,最好將其設置為1M,然後在會話中可以將其作為一個會話變量設置為更年夜的值。

(五)慢速查詢日記

慢速查詢日記是MySQL很有效的一個特征。

1、log_slow_queries

MySQL參數中log_slow_queries參數在my.cnf文件中設置它,將其設置為on,默許情形下,MySQL會將文件放到數據目次,文件以“主機名-slow.log”的情勢定名,但你在設置這個選項的時刻也能夠為其指定一個名字。

2、long_query_time

默許值是10秒,你可以靜態設置它,值從1到將其設置為on,假如數據庫啟動了,默許情形下,日記將封閉。截至5.1.21和裝置了 Google補釘的版本,這個選項可以以微秒設置,這是一個了不得的功效,由於一旦你清除了一切查詢時光跨越1秒的查詢,解釋調劑異常勝利,如許可以贊助 你在成績變年夜之前清除成績SQL。

3、log_queries_not_using_indexes

開啟這個選項是個不錯的主張,它真實地記載了前往一切行的查詢。

小結

我們引見了MySQL參數的五年夜類設置,日常平凡我們普通都很少碰它們,在停止MySQL機能調優和毛病診斷時這些參數照樣異常有效的。

MySQL中的緩存查詢包含兩個解析查詢籌劃,和前往的數據集,假如基本表數據或構造有變更,將會使查詢緩存中的項目有效。

1、query_cache_min_res_unit

MySQL參數中query_cache_min_res_unit查詢緩存中的塊是以這個年夜小停止分派的,應用上面的公式盤算查詢緩存的均勻年夜小,依據盤算成果設置這個變量,MySQL就會更有用地應用查詢緩存,緩存更多的查詢,削減內存的糟蹋。

2、query_cache_size

這個參數設置查詢緩存的總年夜小。

3、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%';

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved