五個影響mysql效能的關鍵配置

2022-03-31 20:50:40 字數 2073 閱讀 3920

(一)連線

連線通常來自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

影響SQL Server效能的關鍵

1 邏輯資料庫和表的設計 資料庫的邏輯設計 包括表與表之間的關係是優化關係型資料庫效能的核心。乙個好的邏輯資料庫設計可以為優化資料庫和應用程式打下良好的基礎。標準化的資料庫邏輯設計包括用多的 有相互關係的窄表來代替很多列的長資料表。下面是一些使用標準化表的一些好處。a 由於表窄,因此可以使排序和建立...

五個影響關鍵詞優化的因素

程式設計客棧 搜尋乙個關鍵詞程式設計客棧時,有幾千幾萬個頁面,站長朋友們當然都希望第乙個就是自己的 影響關鍵字的權重有哪些因素?主要有五方面 大方面 的因素,決定關鍵字權重的大引數 之所以用大引數,是因為小引數還很多 1 這個網頁的pr值 這個網頁主網域名稱的pr值。2 關鍵字在網頁標題中的比重ob...

影響MySql效能的因素

哪些資料不適合存在資料庫中?流水佇列資料 一些系統中,每次交易,存放等都會產生流水佇列資料,資料量非常龐大 那些資料存放在cache 快取 中?減少資料庫的互動次數 在這裡我們列舉乙個n 1的問題,總所周知,在使用mybatis的時候當a物件中包含b物件 也就是乙個物件存在乙個關聯物件 a物件列表中...