對稱多處理(英語:Symmetric multiprocessing,縮寫:SMP),也譯為均衡多處理對稱性多重處理對稱多處理機[1],是一種多處理器的電腦硬體架構,在對稱多處理架構下,每個處理器的地位都是平等的,對資源的使用權限相同。現代多數的多處理器系統,都採用對稱多處理架構,也被稱為對稱多處理系統(Symmetric multiprocessing system)。在這個系統中,擁有超過一個以上的處理器,這些處理器都連接到同一個共享的主記憶體上,並由單一作業系統來控制。在多核心處理器的例子中,對稱多處理架構,將每一個核心都當成是獨立的處理器。

在對稱多處理系統上,在作業系統的支援下,無論行程是處於使用者空間,或是核心空間,都可以分配到任何一個處理器上運行。因此,行程可以在不同的處理器間移動,達到負載平衡,使系統的效率提升。

基本定義

在計算領域,對稱多處理是一種多處理機硬件架構,有兩個或更多的相同的處理機(處理器)共享同一主存,由一個操作系統控制。當前最常見的多處理機系統使用了對稱多處理架構。以多核處理器為例,對稱多處理架構就是這些核,它把這些核當作不同的處理器。不同的處理器之間可以由總線、矩陣開關或片上mesh網絡來連接。使用總線或矩陣開關的對稱多處理架構有可擴展性方面的瓶頸,它是由處理器之間連接的帶寬、能耗,以及內存和磁盤陣列等引起的。使用mesh連接的架構避免了這些瓶頸。它能夠支持更多數量的處理器,具有幾乎線性的可擴展性,代價是犧牲可編程性。

優點與缺點

優點是並行度很高,但是由於系統匯流排的帶寬是有限的,故處理器數目受限,且效能受限。

用途

分時系統服務器系統通常可以在不更改應用程序的情況下使用 SMP,因為它們可能有多個並行運行的進程,並且運行多個進程的系統可以在不同的處理器上運行不同的進程。

個人計算機上,SMP 對於未經修改的應用程序不太有用。如果系統很少同時運行多個進程,則 SMP 僅對已針對多線程(多任務)處理進行修改的應用程序有用。可以編寫或修改定製編程軟件以使用多個線程,以便它可以利用多個處理器。

多線程程序還可以用在支持多線程的分時和服務器系統中,使它們能夠更多地利用多個處理器。

參閱

參考文獻

Wikiwand in your browser!

Seamless Wikipedia browsing. On steroids.

Every time you click a link to Wikipedia, Wiktionary or Wikiquote in your browser's search results, it will show the modern Wikiwand interface.

Wikiwand extension is a five stars, simple, with minimum permission required to keep your browsing private, safe and transparent.