通常一個web應用的性能瓶頸在資料庫。因為,通常情況下php中mysql查詢是串行的。也就是說,如果指定兩條sql語句時,第二條sql語句會等到第一條sql語句執行完畢再去執行。這個時候,如果執行2條sql語句,每條執行時間為50ms,全部執行完畢可能需要100ms。既然,主要原因是sql的串行執行導緻。那我們是不是可以改變執行方式來提高性能呢?答案是,可以的。我們可以通過異步執行的方式來提高性能。
如果通過異步的方式去執行,可能性能會有很大提升。如果是采用異步的方式,兩條sql語句會并發執行,可能就需要60ms就可以執行完畢。
mysqli + mysqlnd。php官方實作的mysqlnd中提供了異步查詢的方法。分别是:
mysqlnd_async_query 發送查詢請求
mysqlnd_reap_async_query 擷取查詢結果
這樣就可以不必每次發送完查詢請求後,一直阻塞等待查詢結果了。
實作代碼如下:
mysql資料庫對于每個查詢請求都是單獨啟動一個線程進行處理。如果mysql伺服器啟動線程過多,必然會造成線程切換引起系統負載過高。如果在mysql資料庫負載不高的情況下,使用異步查詢還是不錯的選擇。