mysql查詢tables cache的最大數:
show variables like table_cache;
mysql查詢當前系統已經打開的描述符命令:
show status like open_tables;
一、調整table cache
table_cache 參數設置表高速緩存的數目。每個連接進來,都會至少打開一個表緩存。因此, table_cache 的大小應與 max_connections 的設置有關。例如,對於 200 個並行運行的連接,應該讓表的緩存至少有 200 × N ,這裡 N 是應用可以執行的查詢的一個聯接中表的最大數量。此外,還需要為臨時表和文件保留一些額外的文件描述符。
當 Mysql 訪問一個表時,如果該表在緩存中已經被打開,則可以直接訪問緩存;如果還沒有被緩存,但是在 Mysql 表緩沖區中還有空間,那麼這個表就被打開並放入表緩沖區;如果表緩存滿了,則會按照一定的規則將當前未用的表釋放,或者臨時擴大表緩存來存放,使用表緩存的好處是可以更快速地訪問表中的內容。
執行 flush tables 會清空緩存的內容。一般來說,可以通過查看數據庫運行峰值時間的狀態值 Open_tables 和 Opened_tables ,判斷是否需要增加 table_cache 的值(其中 open_tables 是當前打開的表的數量, Opened_tables 則是已經打開的表的數量)。即如果open_tables接近table_cache的時候,並且Opened_tables這個值在逐步增加,那就要考慮增加這個值的大小了。還有就是Table_locks_waited比較高的時候,也需要增加table_cache。
二、調整系統和數據庫打開文件數目限制
table_cache加大後碰到文件描述符不夠用的問題。這個時候就需要考慮提高系統和數據庫的打開文件數目限制了。
1,顯示當前系統的文件限制
# cat /proc/sys/fs/file-max
2,通過phpmyadmin查詢mysql配置參數(既open files limit)。
一般情況下,mysql 5的open files limit會自動根據table cache調整。open files limit 系統默認調整為table cache的2倍多一點。