Mysql的優化設定

2021-04-20 02:08:31 字數 2155 閱讀 8938

mysql的優化設定

開啟/etc/my.cnf檔案,修改以下設定,如果沒有,可手動新增。調整設定時,請量力而行,這與你的伺服器的配置有關,特別是記憶體大小。以下設定比較適合於1g記憶體的伺服器,但並不絕對。

#指定索引緩衝區的大小,它決定索引處理的速度,尤其是索引讀的速度。通過檢查狀態值key_read_requests和key_reads,可以知道key_buffer_size設定是否合理。比例key_reads / key_read_requests應該盡可能的低,至少是1:100,1:1000更好(上述狀態值可以使用show status like 』key_reads』獲得)。key_buffer_size只對myisam表起作用。即使你不使用myisam表,但是內部的臨時磁碟表是myisam表,也要使用該值。可以使用檢查狀態值created_tmp_disk_tables得知詳情。

key_buffer = 384m

#要求mysql能有的連線數量。當主要mysql執行緒在乙個很短時間內得到非常多的連線請求,這就起作用,然後主線程花些時間(儘管很短)檢查連線並且啟動乙個新執行緒。back_log值指出在mysql暫時停止回答新請求之前的短時間內多少個請求可以被存在堆疊中。只有如果期望在乙個短時間內有很多連線,你需要增加它,換句話說,這值對到來的tcp/ip連線的偵聽佇列的大小。你的作業系統在這個佇列大小上有它自己的限制。試圖設定back_log高於你的作業系統的限制將是無效的。預設數值是50

back_log = 200

#乙個包的最大尺寸。訊息緩衝區被初始化為net_buffer_length位元組,但是可在需要時增加到max_allowed_packet個位元組。預設地,該值太小必能捕捉大的(可能錯誤)包。如果你正在使用大的blob列,你必須增加該值。它應該象你想要使用的最大blob的那麼大。

max_allowed_packet = 4m

max_connections = 1024

#指定表快取記憶體的大小。每當mysql訪問乙個表時,如果在表緩衝區中還有空間,該錶就被開啟並放入其中,這樣可以更快地訪問表內容。通過檢查峰值時間的狀態值open_tables和opened_tables,可以決定是否需要增加table_cache的值。如果你發現open_tables等於table_cache,並且opened_tables在不斷增長,那麼你就需要增加table_cache的值了(上述狀態值可以使用show status like 』open_tables』獲得)。注意,不能盲目地把table_cache設定成很大的值。如果設定得太高,可能會造成檔案描述符不足,從而造成效能不穩定或者連線失敗。

table_cache = 512

#每個執行緒排序所需的緩衝

sort_buffer_size = 4m

#當乙個查詢不斷地掃瞄某乙個表,mysql會為它分配一段記憶體緩衝區。read_buffer_size變數控制這一緩衝區的大小。如果你認為連續掃瞄進行得太慢,可以通過增加該變數值以及記憶體緩衝區大小提高其效能。

read_buffer_size = 4m

#加速排序操作後的讀資料,提高讀分類行的速度。如果正對遠遠大於可用記憶體的表執行group by或order by操作,應增加read_rnd_buffer_size的值以加速排序操作後面的行讀取。仍然不明白這個選項的用處……

read_rnd_buffer_size = 8m

myisam_sort_buffer_size = 64m

#可以復用的儲存在中的執行緒的數量。如果有,新的執行緒從快取中取得,當斷開連線的時候如果有空間,客戶的線置在快取中。如果有很多新的執行緒,為了提高效能可以這個變數值。通過比較 connections 和 threads_created 狀態的變數,可以看到這個變數的作用。

thread_cache_size = 128

#查詢結果快取。第一次執行某條select語句的時候,伺服器記住該查詢的文字內容和它返回的結果。伺服器下一次碰到這個語句的時候,它不會再次執行該語句。作為代替,它直接從查詢快取中的得到結果並把結果返回給客戶端。

query_cache_size = 32m

#最大併發執行緒數,cpu數量*2

thread_concurrency = 2

#設定超時時間,能避免長連線

wait_timeout = 120

#關閉不需要的表型別,如果你需要,就不要加上這個

skip-innodb

skip-bdb

Mysql的優化設定

開啟 etc my.cnf檔案,修改以下設定,如果沒有,可手動新增。調整設定時,請量力而行,這與你的伺服器的配置有關,特別是記憶體大小。以下設定比較適合於1g記憶體的伺服器,但並不絕對。指定索引緩衝區的大小,它決定索引處理的速度,尤其是索引讀的速度。通過檢查狀態值key read requests和...

mysql的優化 MySQL優化

一 sql語句優化 1 使用limit對查詢結果的記錄進行限定 2 避免select 將需要查詢的字段列出來 3 使用連線 join 來代替子查詢 4 拆分大的delete或insert語句 二 選擇合適的資料型別 1 使用可存下資料的最小的資料型別,整型 date,time char,varcha...

mysql優化一些引數的設定

在整體的系統執行過程中,資料庫伺服器 mysql 的壓力是最大的,不僅占用很多的記憶體和 cpu 資源,而且占用著大部分的磁碟 io 資源,連 php 的官方都在聲稱,說 php 指令碼 80 的時間都在等待 mysql 查詢返回的結果。由此可見,提高系統的負載能力,降低 mysql 的資源消耗迫在...