MySQL為何只用1個核?
MySQL是一種非常流行的關系數據庫管理系統,使用廣泛。不過,相信很多人都會經常遇到一個問題,就是當MySQL執行某些任務的時候,只有一個核心在高負載的情況下在工作,而其他的核心則被輕微的利用甚至不被利用。那么這是為什么呢?
首先,我們需要了解的是,MySQL是由C/C++語言開發而成的,而這兩種語言在處理并發的時候不是這么擅長。這一方面很大程度地影響了MySQL的多線程架構。
MySQL在堆棧層面上是線程安全的,并且擁有大量的鎖,以避免并發干擾。但是,MySQL的核心鎖機制使得許多操作成為順序線程。這導致了一個問題,那就是當MySQL執行一個查詢任務的時候,如果我們希望這個任務并發地使用所有可用的CPU核,那么我們便需要將這個查詢任務拆解成多個查詢任務,并將這些查詢任務委派給數據庫的多個實例,讓這些實例并發地運行這些查詢任務。
然而,那么多個MySQL實例在執行同樣的查詢任務時,又存在一個共有緩存區的問題。這些MySQL實例可以通過共有緩存區相互發消息,但共有緩存區仍舊存在競爭條件。我們需要為共有緩存區設計同步機制,以確保它只被一個MySQL實例使用,而不是所有實例。
這也就是為什么MySQL只使用1個核的原因。這種設計保證了數據一致性和正確性,但同樣也減慢了MySQL的處理速度。因此,在很大程度上,MySQL的設計帶有某種權衡的東西。不過,MySQL繼續不斷地進行優化,以達到并行處理更多任務的目的。