先占 VM 執行個體

本頁介紹的是先占虛擬機器 (VM) 執行個體。有關如何建立先占執行個體的詳情,請參閱建立先占執行個體一節。如要進一步瞭解執行個體的一般資訊,請參閱虛擬機器執行個體說明文件。

什麼是先占執行個體?

先占 VM 是一種執行個體,與一般執行個體相比,建立和執行的價格較低。不過 Compute Engine 在因應其他工作的資源調度需求時,可能會終止 (先占) 這些執行個體。先占執行個體是額外的 Compute Engine 容量,因此其供應情形會隨用量而異。

如果您的應用程式具備容錯能力,且能承受執行個體可能遭到先占的影響,那麼先占執行個體就可大幅節省您的 Compute Engine 費用。例如可在先占執行個體上執行批次處理工作。如果部分執行個體在處理過程中終止,那麼工作執行速度會變慢,但並不會完全停止。先占執行個體不會對現有執行個體造成額外的工作負載,就能完成批次處理工作,且不用全額購買更多一般執行個體。

先占執行個體限制

先占執行個體的功能與一般執行個體類似,但有以下限制:

  • Compute Engine 可能會因系統事件的緣故,隨時終止先占執行個體。一般而言,Compute Engine 因系統事件而終止先占執行個體的可能性很低,但仍需視當前狀況,每天和不同區域間都可能有所差異。
  • 先占執行個體執行 24 小時後,Compute Engine 會一律將之終止。某些操作會重設此 24 小時計數器。
  • 先占執行個體為有限的 Compute Engine 資源,因此可能無法隨時供應。
  • 先占執行個體無法即時遷移至一般 VM 執行個體,或是設為在發生維護作業時自動重新啟動。
  • 由於有上述限制,因此先占執行個體未涵蓋在任何「服務水準協議」內 (明確來說,先占執行個體已排除在 Compute Engine 服務水準協議之外)。
  • Compute Engine 的 Google Cloud Platform 免費方案抵免額不適用於先占執行個體。

先占程序

Compute Engine 會執行下列步驟以先占執行個體:

  1. Compute Engine 以 ACPI G2 Soft Off 信號形式,向執行個體傳送先占通知。您可使用關機指令碼來處理先占通知,並在執行個體停止前完成清除動作。
  2. 如果執行個體未在 30 秒後停止,Compute Engine 會向作業系統傳送 ACPI G3 Mechanical Off 信號。
  3. Compute Engine 將執行個體轉換為 TERMINATED 狀態。

您可藉由停止執行個體,來模擬執行個體先占行為。

遭到先占的執行個體仍會顯示在您的專案中,但只要執行個體仍處於 TERMINATED 狀態,就不會向您收取執行個體的時數費用。您可以存取和還原執行個體所連接的永久磁碟內的資料,但除非刪除磁碟,否則磁碟仍會產生儲存費用。與一般執行個體相同,當您刪除先占執行個體時,亦會刪除標示為自動刪除的永久磁碟。

如果 Compute Engine 在建立先占執行個體後不到一分鐘便將其終止,就不會向您收取該 VM 執行個體的使用費。這樣可確保您不會為先占執行個體付費,除非它們有時間完成大量工作。不過,系統仍會照常計算付費作業系統的費用。

先占選擇

一般來說,Compute Engine 會避免先占單一客戶過多的執行個體,並儘可能搶占新執行個體甚於較舊的執行個體。此策略起初可能會讓人感到不便,但長期運作下有助於將整個叢集的工作中斷狀況降至最低。如果執行個體在開始執行後的第一分鐘內即已先占,則 Compute Engine 不會向您收取執行個體的費用。Google 不會使用 VM 的 CPU 使用率來判定它是否遭到先占。

對歷來資料的觀察結果顯示,每個專案的七天平均每日先占率變動範圍在 5% 至 15% 之間,有時會因時間與區域因素而升高。提醒您,上述觀察資訊僅供參考;對於先占率或先占的分配,先占執行個體不做任何保證,亦無任何服務水準協議。

某些操作會重設先占執行個體的 24 小時計數器。具體來說,在您停止啟動執行個體時,Compute Engine 會因執行個體轉換為 TERMINATED 狀態而重設計數器。不過,當執行個體仍處於 RUNNING 狀態時,其他操作並不會重設計數器,例如重設執行個體,或在 VM 內執行 sudo reboot 時。

代管執行個體群組中的先占執行個體

您可在代管執行個體群組中,建立先占執行個體。請在執行個體範本中指定先占選項,然後再建立或更新群組。

只在有額外的 Compute Engine 資源可供使用時,代管執行個體群組才可建立或新增先占執行個體。如果這些資源受到限制,代管執行個體群組就無法調整規模大小,也無法自動調整群組中的先占執行個體數量。

代管執行個體群組會一直嘗試維持目標大小,或是維持該群組以自動配置器指定的大小。如果 Compute Engine 終止了代管執行個體群組中的先占執行個體,則群組會重複嘗試使用指定的執行個體範本,來重新建立該執行個體。只要重新供應必要資源,群組就會重新建立執行個體並維持目標群組大小。

先占執行個體的付費作業系統

先占執行個體不會降低付費作業系統的費用,也不會改變使用這些作業系統時的計費方式。如果 Compute Engine 終止的是執行付費作業系統的先占執行個體,則會依您自行終止執行個體的收費方式,向您收取該作業系統的費用。您仍需支付基本費用,而系統仍會將用量依計費單位進位成整數,以計算付費作業系統的費用。

在執行付費作業系統的先占執行個體上,機器類型的費用一律會按秒數收費,並以機器類型定價頁面上列出的價格為準。

先占執行個體上的本機 SSD

您可以啟動具有本機 SSD 的先占 VM 執行個體,Compute Engine 會依據先占價格,向您收取本機 SSD 的使用費。連接至先占執行個體的本機 SSD 運作方式與一般本機 SSD 類似,且只會在執行個體存留時常駐。您可以要求先占本機 SSD 的獨立配額,但您也可以選擇在建立先占本機 SSD 時,使用您的一般本機 SSD。

如果本機 SSD 的執行個體在其開始執行後的一分鐘內即已先占,則 Compute Engine 不會向您收取本機 SSD 的使用費用。

如要進一步瞭解本機 SSD,請參閱新增本機 SSD 一文。

先占執行個體上的 GPU

您可以用較低的 GPU 先占價格將 GPU 新增至先占 VM 執行個體。連接至先占執行個體的 GPU,在運作方式上就如同一般的 GPU,但僅會在執行個體的可用期限內保留。具有 GPU 的先占執行個體,其先占程序與其他所有先占執行個體皆相同。

在將 GPU 新增至先占執行個體時,使用的是一般 GPU 配額。如果您的先占 GPU 需要獨立配額,請要求獨立的先占 GPU 配額

在維護作業期間,根據預設會先占具有 GPU 的先占執行個體,且這類執行個體無法自動重新啟動。如要重新建立已先占的執行個體,請使用代管執行個體群組。代管執行個體群組會在 vCPU、記憶體和 GPU 資源可供使用時,重新建立執行個體。

如果您想在執行個體遭到先占前收到警告,或是想將執行個體設定成在維護作業過後自動重新啟動,請使用具有 GPU 的非先占執行個體。針對具有 GPU 的非先占執行個體,Google 會在先占此類執行個體的一小時前預先通知

如果 GPU 的執行個體在其開始執行後的一分鐘內即已先占,則 Compute Engine 不會向您收取 GPU 的使用費。

如需自動重新啟動非先占執行個體的步驟,請參閱更新執行個體的選項一節。

要瞭解如何建立附加 GPU 的先占執行個體,請參閱建立具有 GPU 的執行個體一節。

測試先占設定

您可在執行個體上執行模擬維護作業,以強制先占這些執行個體。使用這項功能可測試應用程式處理先占執行個體的方式。請參閱測試您的可用性政策一節,瞭解如何在執行個體上測試維護作業。

您也可以停止執行個體,藉以模擬執行個體先占行為,這個模擬操作可用來取代模擬維護作業,並避免超過配額限制。

後續步驟

本頁內容對您是否有任何幫助?請提供意見:

傳送您對下列選項的寶貴意見...

這個網頁
Compute Engine 說明文件