Spot VM


本頁說明 Spot VM:虛擬機器 (VM) 執行個體,屬於 Compute Engine 的剩餘容量。Spot VM 的折扣幅度相當可觀,但 Compute Engine 可能隨時會搶占 Spot VM,藉此回收容量,Spot VM 是先占 VM 的最新版本。

Spot VM 是指使用Spot 佈建模式的 VM。 與標準 VM 相比,這個佈建模式可讓您以低得多的價格取得資源。不過,Compute Engine 隨時可能會搶佔 Spot VM,以回收資源。使用 Spot VM 降低容錯工作負載的成本。

如要進一步瞭解 Compute Engine VM,請參閱虛擬機器執行個體說明文件。如要瞭解如何建立 Spot VM,請參閱「建立及使用 Spot VM」。

什麼是 Spot VM?

Spot VM 的價格比標準 VM 的以量計價價格低得多,多數機型和 GPU 享有 60% 至 91% 的折扣,其他資源則享有較低折扣。不過,Compute Engine 隨時可能會搶占 Spot VM,例如需要將資源用於其他工作時。在不確定的搶佔時間,Compute Engine 會根據您為每個 Spot VM 指定的終止動作,停止 (預設) 或刪除 Spot VM。Spot VM 是額外的 Compute Engine 容量,因此供應情形會因 Compute Engine 用量而異。除非您限制執行時間,否則 Spot VM 沒有執行時間下限或上限。

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

Spot VM 限制

Spot VM 的功能與標準 VM 類似,但有以下限制:

  • Compute Engine 可能隨時會搶占 Spot VM,以回收資源。Compute Engine 會因各種原因 (例如系統事件) 預先終止 Spot VM。一般而言,Compute Engine 預先終止 Spot VM 的可能性很低,但仍需視當前狀況,每天和不同區域間都可能有所差異。詳情請參閱本文的「搶占選取」一節。
  • Spot VM 是有限的 Compute Engine 資源,因此可能無法隨時供應。
  • Spot VM 無法在運作時即時遷移並成為標準 VM,也無法設為在發生主機事件自動重新啟動
  • 由於有上述限制,因此 Spot VM 未涵蓋在任何「服務水準協議」內,且已排除在 Compute Engine 服務水準協議之外。
  • Compute Engine 的Google Cloud 免費方案抵免額不適用於 Spot VM。
  • 只有支援的機器類型才能使用 Spot VM。

Spot VM 先占

本節說明 Compute Engine 如何先占 Spot VM,以及系統會選取哪些 VM 進行先占。

先占程序

Compute Engine 會執行下列步驟,先占 Spot VM:

  1. Compute Engine 會以 ACPI G2 Soft Off 信號形式,向 VM 傳送先占通知。您可使用關機指令碼來處理先占通知,並在 VM 停止前完成清除動作。先占通知的關機時間會盡量以最佳方式執行,最長為 30 秒。
  2. 如果 Spot VM 在先占通知的關機期限過後仍未停止,Compute Engine 會向作業系統傳送 ACPI G3 Mechanical Off 信號。
  3. Spot VM 的最終狀態取決於您為每個 VM 指定的終止動作
    • 如果終止動作設為 STOP 或未指定,Compute Engine 會停止 VM,將 VM 轉換為 TERMINATED 狀態
    • 如果終止動作設為 DELETE,Compute Engine 會刪除 VM。

您可以停止 VM刪除 VM,模擬 VM 先占行為。

如果遭到先占的 VM 已停止運作,仍會顯示在專案中,但只要 VM 仍處於 TERMINATED 狀態,就不會向您收取 VM 的時數費用。您可以存取和還原 VM 所連接的永久磁碟內的資料,但除非刪除磁碟,否則磁碟仍會產生儲存費用。與標準 VM 相同,當您刪除 Spot VM 時,系統會刪除標示為自動刪除的永久磁碟。

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

先占選擇

當 Spot VM 處於 RUNNING 狀態時,可能會遭到搶占;處於 TERMINATED 狀態時,則不會遭到搶占。因此,您可以停止重新啟動 Spot VM,藉此重設搶占程序,因為停止 VM 會讓 VM 處於 TERMINATED 狀態。只要有容量,您就能視需要多次停止及重新啟動遭先占的 Spot VM。請注意,重設或重新啟動 VM 會讓 VM 處於 RUNNING 狀態,因此不會重設搶占程序。

您無法查看任何特定搶占事件發生的原因。與資源可用性錯誤類似,不同可用區、不同時間或不同資源的搶占率可能有所不同。如需降低搶占率的具體建議,請參閱最佳做法

定價

Spot 價格 (Spot VM 的價格) 提供相當優惠的 VM 折扣。與標準價格相比,Spot 價格提供 60% 至 91% 的折扣,適用於多數機型和 GPU。此外,Spot VM 的任何 A4 或 A3 機器類型和 GPU、本機 SSD、外部 IP 位址和 Tier_1 網路費用,折扣幅度較小。自訂機型的價格會比標準機型多出附加費率。自訂機型的 Spot 價格已包含這筆附加費用。

請注意,如果先占 VM 已停止,只要 VM 仍處於 TERMINATED 狀態,就不會收取 VM 時數費用。您可以存取和還原 VM 所連接的永久磁碟內的資料,但除非刪除磁碟,否則磁碟仍會產生儲存費用。進一步瞭解執行個體正常運作時間磁碟定價

如要查看 Spot VM 的最新價格,請參閱 Spot VM 定價頁面、使用 Cloud Billing Catalog API,或註冊接收 Spot VM 的價格公告

搭配 Compute Engine 使用 Spot VM

本節提供搭配其他 Compute Engine 產品使用 Spot VM 時的注意事項。瞭解如何搭配代管執行個體群組、進階作業系統、本機 SSD 和 GPU 使用 Spot VM。此外,也請瞭解 Spot VM 對 Compute Engine 資源配額的影響。

代管執行個體群組中的 Spot VM

您可以使用 gcloud CLICompute Engine API,在受管理執行個體群組中建立 Spot VM。請在執行個體範本中指定建立 Spot VM 的選項,然後再建立或更新群組。

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

代管執行個體群組會一直嘗試維持目標大小,或是維持該群組以自動配置器指定的大小。如果 Compute Engine 停止代管執行個體群組中的一或多個 Spot VM,則群組會重複嘗試使用指定的執行個體範本,來重新建立這些 VM。如果必要資源再度可用,群組會重新建立 VM,並維持目標群組大小。

Spot VM 的付費作業系統

Spot VM 不會降低付費作業系統的費用,也不會改變使用這些作業系統時的計費方式。如果 Compute Engine 停止了執行付費作業系統的 Spot VM,我們針對該作業系統收費時,會視為您自行停止 VM。您仍需支付基本費用,而系統仍會將用量依計費單位進位成整數,以計算付費作業系統的費用。

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

Spot VM 上的本機 SSD

您可以啟動具有本機 SSD 的 Spot VM,Compute Engine 會依據Spot 價格,向您收取本機 SSD 的使用費。連接至 Spot VM 的本機 SSD 運作方式與一般本機 SSD 類似,會保留相同的資料保存特性,且在 VM 存留期間保持連線。

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

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

Spot VM 上的 GPU

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

建議您申請專屬 Preemptible GPU 配額,用於 Spot VM 上的 GPU。詳情請參閱「Spot VM 配額」。

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

如果您想在 VM 遭到先占前收到警告,或是想將 VM 設定成在維護作業過後自動重新啟動,請使用具有 GPU 的標準 VM。對於搭載 GPU 的標準 VM,Compute Engine 會在先占前提前一小時通知

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

如要瞭解如何建立附加 GPU 的 Spot VM,請參閱「建立附加 GPU 的 VM」和「建立 Spot VM」。舉例來說,請參閱「使用 Spot VM 建立 A3 Ultra 或 A4 執行個體」。

Spot VM 配額

與其他 VM 相同,Spot VM 也需要可用的 CPU 配額。此外,如果您打算使用本機 SSD 或 GPU 搭配 Spot VM,Spot VM 也分別需要磁碟配額GPU 配額

如果您使用 Spot VM 搭配這些資源,但未要求先占配額,Spot VM 會耗用這些資源的標準配額。如果您打算使用 Spot VM,請考慮為這些資源要求搶占配額,以免 Spot VM 耗用其他配額。

當 Compute Engine 授予您某個地區的先占配額後,該地區的所有 Spot VM (和任何先占 VM) 都會計入該配額。該區域中的所有標準 VM 仍會計入標準配額。在沒有先占配額的地區,您可以使用標準配額啟動 Spot VM。

除非 Compute Engine 已授予配額,否則先占配額不會出現在 gcloud CLI 或Google Cloud 控制台配額頁面中。詳情請參閱「先占資源的分配配額」。

後續步驟

歡迎試用

如果您未曾使用過 Google Cloud,歡迎建立帳戶,親自體驗實際使用 Compute Engine 的成效。新客戶可以獲得價值 $300 美元的免費抵免額,可用於執行、測試及部署工作負載。

免費試用 Compute Engine