您可以手動停止 Compute Engine 執行個體,或修改其屬性 (例如變更機型,或移除任何已連結及掛接的磁碟)。執行個體停止後,您可以重新啟動執行個體以繼續執行工作負載,或刪除不再需要的執行個體。
本文說明如何手動停止或重新啟動執行個體。如要自動停止或重新啟動執行個體,請參閱下列文章:
限制
停止運算執行個體時,會受到下列限制:
只有在執行個體狀態允許的情況下,才能停止或重新啟動執行個體。
只有在執行個體所在可用區有足夠資源時,才能重新啟動執行個體。
您無法重新啟動 TPU 執行個體。
事前準備
-
如果尚未設定驗證,請先完成設定。
驗證可確認您的身分,以便存取 Google Cloud 服務和 API。如要從本機開發環境執行程式碼或範例,請選取下列其中一個選項,向 Compute Engine 進行驗證:
選取這個頁面上的分頁,瞭解您打算如何使用範例:
控制台
使用 Google Cloud 控制台存取 Google Cloud 服務和 API 時,無須設定驗證。
gcloud
-
安裝 Google Cloud CLI。 完成後,執行下列指令來初始化 Google Cloud CLI:
gcloud init若您採用的是外部識別資訊提供者 (IdP),請先使用聯合身分登入 gcloud CLI。
-
- 設定預設地區和區域。
-
安裝 Google Cloud CLI。
-
若您採用的是外部識別資訊提供者 (IdP),請先使用聯合身分登入 gcloud CLI。
-
如果您使用本機殼層,請為使用者帳戶建立本機驗證憑證:
gcloud auth application-default login
如果您使用 Cloud Shell,則不需要執行這項操作。
如果系統傳回驗證錯誤,且您使用外部識別資訊提供者 (IdP),請確認您已 使用聯合身分登入 gcloud CLI。
-
安裝 Google Cloud CLI。
-
若您採用的是外部識別資訊提供者 (IdP),請先使用聯合身分登入 gcloud CLI。
-
如果您使用本機殼層,請為使用者帳戶建立本機驗證憑證:
gcloud auth application-default login
如果您使用 Cloud Shell,則不需要執行這項操作。
如果系統傳回驗證錯誤,且您使用外部識別資訊提供者 (IdP),請確認您已 使用聯合身分登入 gcloud CLI。
-
安裝 Google Cloud CLI。
-
若您採用的是外部識別資訊提供者 (IdP),請先使用聯合身分登入 gcloud CLI。
-
如果您使用本機殼層,請為使用者帳戶建立本機驗證憑證:
gcloud auth application-default login
如果您使用 Cloud Shell,則不需要執行這項操作。
如果系統傳回驗證錯誤,且您使用外部識別資訊提供者 (IdP),請確認您已 使用聯合身分登入 gcloud CLI。
-
安裝 Google Cloud CLI。
-
若您採用的是外部識別資訊提供者 (IdP),請先使用聯合身分登入 gcloud CLI。
-
如果您使用本機殼層,請為使用者帳戶建立本機驗證憑證:
gcloud auth application-default login
如果您使用 Cloud Shell,則不需要執行這項操作。
如果系統傳回驗證錯誤,且您使用外部識別資訊提供者 (IdP),請確認您已 使用聯合身分登入 gcloud CLI。
-
安裝 Google Cloud CLI。
-
若您採用的是外部識別資訊提供者 (IdP),請先使用聯合身分登入 gcloud CLI。
-
如果您使用本機殼層,請為使用者帳戶建立本機驗證憑證:
gcloud auth application-default login
如果您使用 Cloud Shell,則不需要執行這項操作。
如果系統傳回驗證錯誤,且您使用外部識別資訊提供者 (IdP),請確認您已 使用聯合身分登入 gcloud CLI。
Go
如要在本機開發環境中使用本頁的 Go 範例,請安裝並初始化 gcloud CLI,然後使用使用者憑證設定應用程式預設憑證。
詳情請參閱 這篇文章,瞭解如何設定本機開發環境的驗證機制。
Java
如要在本機開發環境中使用本頁面的 Java 範例,請安裝並初始化 gcloud CLI,然後使用使用者憑證設定應用程式預設憑證。
詳情請參閱 這篇文章,瞭解如何設定本機開發環境的驗證機制。
Node.js
如要在本機開發環境中使用本頁的 Node.js 範例,請安裝並初始化 gcloud CLI,然後使用使用者憑證設定應用程式預設憑證。
詳情請參閱 這篇文章,瞭解如何設定本機開發環境的驗證機制。
PHP
如要在本機開發環境中使用本頁的 PHP 範例,請安裝並初始化 gcloud CLI,然後使用使用者憑證設定應用程式預設憑證。
詳情請參閱 這篇文章,瞭解如何設定本機開發環境的驗證機制。
Python
如要在本機開發環境中使用本頁的 Python 範例,請安裝並初始化 gcloud CLI,然後使用您的使用者憑證設定應用程式預設憑證。
詳情請參閱 這篇文章,瞭解如何設定本機開發環境的驗證機制。
REST
如要在本機開發環境中使用本頁的 REST API 範例,請使用您提供給 gcloud CLI 的憑證。
安裝 Google Cloud CLI。
若您採用的是外部識別資訊提供者 (IdP),請先使用聯合身分登入 gcloud CLI。
詳情請參閱 Google Cloud 驗證說明文件中的「使用 REST 進行驗證」。
必要的角色
如要取得停止或重新啟動 Compute 執行個體所需的權限,請要求管理員授予您專案的「Compute 執行個體管理員 (v1)」 (roles/compute.instanceAdmin.v1) IAM 角色。如要進一步瞭解如何授予角色,請參閱「管理專案、資料夾和組織的存取權」。
這個預先定義的角色具備停止或重新啟動運算執行個體所需的權限。如要查看確切的必要權限,請展開「Required permissions」(必要權限) 部分:
所需權限
如要停止或重新啟動運算執行個體,您必須具備下列權限:
-
如要停止執行個體,請執行下列操作:
compute.instances.stop在執行個體上 -
如要從客層 OS 停止執行個體:
compute.instances.setMetadata執行個體 (如果使用執行個體層級的公開 SSH 金鑰)。 -
如要重新啟動執行個體,請按照下列指示操作:
compute.instances.start執行個體 -
如要重新啟動使用加密金鑰的執行個體,請執行下列操作:
compute.instances.startWithEncryptionKey在執行個體上
停止執行個體
停止運算執行個體時,或 Compute Engine 因排定動作而停止執行個體時,執行個體會保留其附加磁碟、設定設定、IP 位址、MAC 位址和執行個體中繼資料。如要保留記憶體內資料和應用程式狀態,請暫停執行個體。
視執行個體是否已連結本機 SSD 磁碟,以及您要如何處理任何關機指令碼,請使用下列其中一種方法停止執行個體:
從 Google Cloud停止執行個體。您可以從 Google Cloud同時停止一或多個執行個體。如果執行個體已連結本機 SSD 磁碟,您可以選擇捨棄或保留 (預覽) 本機 SSD 資料。執行個體中的所有關機指令碼都必須在預設關機期限內完成執行。
如需操作說明,請參閱下列文章:
從訪客 OS 停止執行個體。您可以從訪客 OS 停止單一執行個體。這種做法可讓您在執行個體的關機指令碼執行完畢後,再停止執行個體。如果您已啟用正常關機,也可以停止執行個體,不必正常關機,或結束進行中的正常關機程序。除非您手動將任何附加本機 SSD 磁碟的資料備份到耐久儲存空間磁碟區,否則從訪客 OS 停止執行個體會捨棄這些磁碟上的所有資料。
如需操作說明,請參閱「從客體 OS 停止執行個體」。
停止沒有本機 SSD 硬碟的執行個體
視您停止執行個體時要執行的操作而定,請使用下列選項:
如果您已在執行個體中啟用正常關機,可以使用 Google Cloud 控制台、gcloud CLI 或 REST API 停止執行個體,不必正常關機,也可以終止進行中的正常關機程序。
如要同時停止多個執行個體,請使用 Google Cloud 控制台,或針對位於相同區域的執行個體使用 gcloud CLI。
如要停止一或多個執行個體,請選取下列其中一個選項:
控制台
前往 Google Cloud 控制台的「VM instances」(VM 執行個體) 頁面。
選取要停止的執行中執行個體。
按一下「停止」。如果沒有「停止」選項,請依序點選「更多動作」 >「停止」。
然後在隨即顯示的對話方塊中,執行以下操作:
選用:如要停止執行個體,但不正常關閉執行個體,或結束進行中的正常關機程序,請選取「Skip graceful shutdown (if applicable)」(略過正常關機程序 (如適用)) 核取方塊。
按一下「停止」確認操作。
gcloud
如要停止同一區域中的一或多個執行個體,請使用 gcloud compute instances stop 指令:
gcloud compute instances stop INSTANCE_NAMES \
--zone=ZONE
更改下列內容:
INSTANCE_NAMES:以空格分隔的執行個體名稱清單,例如instance-01 instance-02 instance-03。ZONE:執行個體所在的區域。
如果已在一或多個執行個體中啟用正常關機,您可以停止執行個體,而不正常關機,也可以手動結束進行中的正常關機。做法是使用 gcloud beta compute instances stop 指令,並加上 --no-graceful-shutdown 旗標:
gcloud beta compute instances stop INSTANCE_NAMES \
--no-graceful-shutdown \
--zone=ZONE
Go
Java
Node.js
PHP
Python
REST
如要停止執行個體,請對 instances.stop 方法發出 POST 要求:
POST https://compute.googleapis.com/compute/v1/projects/PROJECT_ID/zones/ZONE/instances/INSTANCE_NAME/stop
更改下列內容:
INSTANCE_NAME:執行個體的名稱。PROJECT_ID:執行個體所在的專案 ID。ZONE:執行個體所在的區域。
如果已在執行個體中啟用正常關機功能,您可以停止執行個體,不必正常關機,也可以手動結束進行中的正常關機程序。如要這麼做,請向 instances.stop 方法發出 POST 要求。在要求網址中加入 noGracefulShutdown=true 查詢參數:
POST https://compute.googleapis.com/compute/beta/projects/PROJECT_ID/zones/ZONE/instances/VM_NAME/stop?noGracefulShutdown=true
停止具有本機 SSD 磁碟的執行個體
視您想在停止運算執行個體時執行的操作而定,請使用下列選項:
如果您已在執行個體中啟用正常關機,可以使用 Google Cloud 控制台、gcloud CLI 或 REST API 停止執行個體,不必正常關機,也可以結束進行中的正常關機程序。
如要保留連結至執行個體的本機 SSD 磁碟資料 (使用 Titanium SSD 的機器類型除外),請使用 gcloud CLI 或 REST API 停止執行個體。
如要同時停止多個執行個體,請使用 Google Cloud 控制台,或針對位於相同區域的執行個體使用 gcloud CLI。
如要停止一或多個已連結本機 SSD 磁碟的執行個體,請選取下列其中一個選項:
控制台
前往 Google Cloud 控制台的「VM instances」(VM 執行個體) 頁面。
選取要停止的執行中執行個體。
按一下「停止」。如果沒有「停止」選項,請依序點選「更多動作」 >「停止」。
在對話方塊中執行下列操作:
選用:如要停止執行個體,但不要正常關機,或是要結束進行中的正常關機程序,請選取「Skip graceful shutdown (if applicable)」(略過正常關機 (如適用)) 核取方塊。
按一下「停止」確認操作。
gcloud
停止同一區域中一或多個已連結本機 SSD 磁碟的執行個體時,請指定是否要捨棄或保留本機 SSD 資料,方法如下:
如要捨棄本機 SSD 資料,請使用
gcloud compute instances stop指令並加上--discard-local-ssd=true旗標:gcloud compute instances stop INSTANCE_NAMES \ --discard-local-ssd=true \ --zone=ZONE如要保留本機 SSD 資料,請搭配
--discard-local-ssd=false旗標使用gcloud beta compute instances stop指令:gcloud beta compute instances stop INSTANCE_NAMES \ --discard-local-ssd=false \ --zone=ZONE
更改下列內容:
INSTANCE_NAMES:以空格分隔的執行個體名稱清單,例如instance-01 instance-02 instance-03。ZONE:執行個體所在的區域。
或者,如果您已在一或多個執行個體中啟用正常關機,您可以停止執行個體,而不正常關機,也可以結束進行中的正常關機。做法是使用 gcloud beta compute instances stop 指令,並加上 --no-graceful-shutdown 旗標:
gcloud beta compute instances stop INSTANCE_NAMES \
--discard-local-ssd=DISCARD_LOCAL_SSD \
--no-graceful-shutdown \
--zone=ZONE
請將 DISCARD_LOCAL_SSD 換成 true,捨棄本機 SSD 磁碟中的資料,或換成 false,保留資料。
REST
停止已連結本機 SSD 磁碟的執行個體時,請指定是否要捨棄或保留本機 SSD 資料,方法如下:
如要捨棄本機 SSD 資料,請向
instances.stop方法發出POST要求。在要求網址中,加入設為true的discardLocalSsd查詢參數:POST https://compute.googleapis.com/compute/v1/projects/PROJECT_ID/zones/ZONE/instances/INSTANCE_NAME/stop?discardLocalSsd=true如要保留本機 SSD 資料,請對
beta.instances.stop方法發出POST要求。在要求網址中,加入設為false的discardLocalSsd查詢參數:POST https://compute.googleapis.com/compute/beta/projects/PROJECT_ID/zones/ZONE/instances/INSTANCE_NAME/stop?discardLocalSsd=false
更改下列內容:
PROJECT_ID:執行個體所在的專案 ID。ZONE:執行個體所在的區域。INSTANCE_NAME:執行個體的名稱。
如果已在執行個體中啟用正常關機功能,您可以選擇停止執行個體,而不正常關機,也可以手動結束進行中的正常關機程序。如要這麼做,請向 instances.stop 方法發出 POST 要求。在要求網址中加入 noGracefulShutdown=true 查詢參數:
POST https://compute.googleapis.com/compute/beta/projects/PROJECT_ID/zones/ZONE/instances/VM_NAME/stop?discardLocalSsd=DISCARD_LOCAL_SSD&noGracefulShutdown=true
請將 DISCARD_LOCAL_SSD 換成 true,捨棄本機 SSD 磁碟中的資料,或換成 false,保留資料。
從客體 OS 停止執行個體
如果運算執行個體已連結本機 SSD 磁碟,關閉訪客 OS 時,系統會自動捨棄本機 SSD 資料。如要保留這項資料,請在停止執行個體前,手動將資料複製到永久儲存空間選項。
如要從客體 OS 停止執行個體,請選取下列其中一個選項:
Linux
如果尚未連線,請連線至執行個體。
如要停止執行個體,請選取下列其中一種做法:
如要執行乾淨關機作業,讓執行個體在關閉客體 OS 前執行關機指令碼,請執行下列指令:
sudo shutdown -h now否則,如要強制關機,請執行下列指令:
sudo poweroff
Windows
如果尚未連線至執行個體,請使用下列其中一種方法:
如要停止執行個體,請選取下列其中一種做法:
如要乾淨停止執行個體,並讓執行個體在關閉客體 OS 前執行關機指令碼,請執行下列指令:
shutdown /s如要強制關機,請執行下列指令:
shutdown /f
重新啟動執行個體
您可以重新啟動已完全停止的運算執行個體 (執行個體狀態為 TERMINATED)。
如果您選擇在停止執行個體時保留本機 SSD 磁碟的資料,可能需要在重新啟動執行個體後重新掛接本機 SSD 磁碟。如要進一步瞭解如何掛接本機 SSD 磁碟,請參閱「格式化及掛接本機 SSD 裝置」。
如要重新啟動執行個體,請根據執行個體是否具有以客戶提供的加密金鑰 (CSEK) 加密的磁碟,使用下列其中一種方法:
如果執行個體未連結 CSEK 加密磁碟,請參閱「重新啟動未連結 CSEK 加密磁碟的執行個體」。
否則,請參閱「重新啟動具有 CSEK 加密磁碟的執行個體」。
重新啟動沒有 CSEK 加密磁碟的執行個體
如要同時重新啟動不同可用區的多個執行個體,請使用Google Cloud 控制台。如要重新啟動位於同一可用區的執行個體,請使用 gcloud CLI。如要重新啟動其他執行個體,請選取下列其中一個選項:
控制台
前往 Google Cloud 控制台的「VM instances」(VM 執行個體) 頁面。
選取一或多個執行個體。
按一下「啟動 / 繼續」圖示 。
gcloud
如要重新啟動同一區域中的一或多個執行個體,請使用 gcloud compute instances start 指令:
gcloud compute instances start INSTANCE_NAMES \
--zone=ZONE
更改下列內容:
INSTANCE_NAMES:以空格分隔的執行個體名稱清單,例如instance-01 instance-02 instance-03。ZONE:執行個體所在的區域。
Go
Java
Node.js
PHP
Python
REST
如要重新啟動執行個體,請對 instances.start 方法發出 POST 要求:
POST https://compute.googleapis.com/compute/v1/projects/PROJECT_ID/zones/ZONE/instances/INSTANCE_NAME/start
更改下列內容:
INSTANCE_NAME:要重新啟動的執行個體名稱。PROJECT_ID:執行個體所在的專案 ID。ZONE:執行個體所在的區域。
重新啟動具有 CSEK 加密磁碟的執行個體
重新啟動已停止的運算執行個體時,如果該執行個體已連結使用客戶提供的加密金鑰加密的磁碟,您必須提供加密金鑰資訊。
如要同時重新啟動不同可用區的多個執行個體,請使用Google Cloud 控制台。如要重新啟動位於同一可用區的執行個體,請使用 gcloud CLI。如要重新啟動其他執行個體,請選取下列其中一個選項:
控制台
前往 Google Cloud 控制台的「VM instances」(VM 執行個體) 頁面。
選取要重新啟動的執行個體。
按一下「啟動 / 繼續」圖示 。
為連接到執行個體的每個加密磁碟指定加密金鑰,然後按一下「啟動」。
gcloud
如要重新啟動同一區域中一或多個使用加密磁碟的執行個體,請使用 gcloud compute instances start 指令搭配 --csek-key-file 旗標。如果您使用的是 RSA 包裝金鑰,請改用 gcloud beta compute instances start 指令並加上 --csek-key-file 標記:
gcloud compute instances start INSTANCE_NAMES \
--csek-key-file=ENCRYPTION_KEY_FILE \
--zone=ZONE
更改下列內容:
INSTANCE_NAMES:以空格分隔的執行個體名稱清單,例如instance-01 instance-02 instance-03。ENCRYPTION_KEY_FILE:包含客戶提供加密金鑰的 JSON 檔案相對路徑。只有當執行個體使用相同的客戶提供加密金鑰時,您才能同時重新啟動多個執行個體。檔案格式請參閱「金鑰檔案格式」。ZONE:執行個體所在的區域。
Go
Java
Node.js
PHP
Python
REST
如要重新啟動使用加密磁碟的執行個體,請對 instances.startWithEncryptionKey 方法發出 POST 要求:
POST https://compute.googleapis.com/compute/v1/projects/PROJECT_ID/zones/ZONE/instances/INSTANCE_NAME/startWithEncryptionKey
{
"disks": [
{
"source": "DISK_URL",
"diskEncryptionKey": {
"ENCRYPTION_TYPE": "ENCRYPTION_KEY"
}
}
]
}
更改下列內容:
PROJECT_ID:執行個體所在的專案 ID。ZONE:執行個體所在的區域。INSTANCE_NAME:執行個體的名稱。DISK_URL:資源網址,對應於已連接磁碟的完整資源名稱,該磁碟已使用客戶提供的加密金鑰加密。ENCRYPTION_TYPE:您使用的磁碟加密類型,可以是下列其中一種:rawKey、kmsKeyName或rsaEncryptedKey。如果您使用rsaEncryptedKey類型,請向beta.instances.startWithEncryptionKey方法提出POST要求。ENCRYPTION_KEY:用來加密連結至執行個體的永久磁碟的加密金鑰。rawKey或rsaEncryptedKey金鑰必須經過 Base64 編碼。此外,如要準備rsaEncryptedKey金鑰,請參閱「RSA 金鑰包裝」。