mysql processlist 提示 Writing to net解決

mysql提示Writing to net解決mysql

最近發現某一個數據庫cpu佔用比較過。超過200%了。
首先查看數據庫慢日誌,設定慢日誌5秒,基本上沒有產生日,沒有超過5秒的語句。
show full processlist;

後發現幾條select有幾個表查詢須要1-2秒,
explain select * from xxx ,發現沒有走索引,全表掃描,之前數據量少那會很快就出來了,目前查詢總數據都在2萬之內,如今數據量大了,其它表都1000w級了,之前只優化了大表的索引,因此問題就突出了。索引建完後CPU明顯示降低,據我瞭解,msyql cpu佔用高,80%的狀況未使用索引有關。

在次show processlist
發現多條語句狀態爲Writing to net
經過分析基本都是select 語句,都是查詢數據太數據庫返回網絡回寫不贏,
查看show global variables like "global max_allowed_packet" 只有1M

經過增長緩存
set global max_allowed_packet =134217728

問題獲得解決!緣由是多條select 返回數據越過緩存超過默認設置。sql


Writing to net
The server is writing a packet to the network.
是一條語句查詢結果比較多引發的,把整個數據庫都拖住了。

數據庫

相關文章
相關標籤/搜索