您可以透過現有的 Compute Engine Windows Server 映像檔,建立自訂 Windows Server 映像檔。使用這些自訂映像檔建立執行個體,並使用與現有執行個體相同的開機磁碟。
對於在現有執行個體上保存作業系統的配置,以及重新使用相同的配置來建立其他執行個體,這些自訂映像檔非常實用。
本節未涵蓋下列工作:
- 從公開映像檔或自訂映像檔建立 VM;請改為參閱「建立新的 Windows 執行個體」。
- 排定永久磁碟備份作業;請改用永久磁碟快照。
- 匯入 Windows Server 或 SQL Server 系統;請改用 VM 遷移服務。
事前準備
- 
  
  如果尚未設定驗證,請先完成設定。
  驗證可確認您的身分,以便存取 Google Cloud 服務和 API。如要從本機開發環境執行程式碼或範例,可以選取下列任一選項,向 Compute Engine 進行驗證:
  
   
   
     
   
  
   
   
     
   
  
   
   
     
   
  
 
 
 
  
    
      Select the tab for how you plan to use the samples on this page: ConsoleWhen you use the Google Cloud console to access Google Cloud services and APIs, you don't need to set up authentication. gcloud- 
 
 
  
  
   
   
  
   
   
  
   
   
     
   
  
  
   
   
  
   
   
  
   
   
  
 
 
   
   
      安裝 Google Cloud CLI。 安裝完成後,執行下列指令初始化 Google Cloud CLI: gcloud init如果您使用外部識別資訊提供者 (IdP),請先 使用聯合身分登入 gcloud CLI。 
- Set a default region and zone.
 Go如要在本機開發環境中使用本頁的 Go 範例,請安裝並初始化 gcloud CLI,然後使用使用者憑證設定應用程式預設憑證。 安裝 Google Cloud CLI。 如果您使用外部識別資訊提供者 (IdP),請先 使用聯合身分登入 gcloud CLI。 If you're using a local shell, then create local authentication credentials for your user account: gcloud auth application-default login You don't need to do this if you're using Cloud Shell. If an authentication error is returned, and you are using an external identity provider (IdP), confirm that you have signed in to the gcloud CLI with your federated identity. 詳情請參閱 Set up authentication for a local development environment。 Java如要在本機開發環境中使用本頁的 Java 範例,請安裝並初始化 gcloud CLI,然後使用使用者憑證設定應用程式預設憑證。 安裝 Google Cloud CLI。 如果您使用外部識別資訊提供者 (IdP),請先 使用聯合身分登入 gcloud CLI。 If you're using a local shell, then create local authentication credentials for your user account: gcloud auth application-default login You don't need to do this if you're using Cloud Shell. If an authentication error is returned, and you are using an external identity provider (IdP), confirm that you have signed in to the gcloud CLI with your federated identity. 詳情請參閱 Set up authentication for a local development environment。 Node.js如要在本機開發環境中使用本頁的 Node.js 範例,請安裝並初始化 gcloud CLI,然後使用使用者憑證設定應用程式預設憑證。 安裝 Google Cloud CLI。 如果您使用外部識別資訊提供者 (IdP),請先 使用聯合身分登入 gcloud CLI。 If you're using a local shell, then create local authentication credentials for your user account: gcloud auth application-default login You don't need to do this if you're using Cloud Shell. If an authentication error is returned, and you are using an external identity provider (IdP), confirm that you have signed in to the gcloud CLI with your federated identity. 詳情請參閱 Set up authentication for a local development environment。 Python如要在本機開發環境中使用本頁的 Python 範例,請安裝並初始化 gcloud CLI,然後使用使用者憑證設定應用程式預設憑證。 安裝 Google Cloud CLI。 如果您使用外部識別資訊提供者 (IdP),請先 使用聯合身分登入 gcloud CLI。 If you're using a local shell, then create local authentication credentials for your user account: gcloud auth application-default login You don't need to do this if you're using Cloud Shell. If an authentication error is returned, and you are using an external identity provider (IdP), confirm that you have signed in to the gcloud CLI with your federated identity. 詳情請參閱 Set up authentication for a local development environment。 REST如要在本機開發環境中使用本頁的 REST API 範例,請使用您提供給 gcloud CLI 的憑證。 安裝 Google Cloud CLI。 如果您使用外部識別資訊提供者 (IdP),請先 使用聯合身分登入 gcloud CLI。 詳情請參閱 Google Cloud 驗證說明文件中的「Authenticate for using REST」。 準備建立 Windows Server 映像檔在您建立映像檔之前,請在執行個體上執行 GCESysprep,以針對映像檔建立程序做好準備。GCESysprep會完成下列步驟,準備將執行個體轉換為 Compute Engine 映像檔:- 停用 GCEStartup排程工作。
- 刪除暫存資料夾位置中的所有檔案。
- 清除所有 Windows 事件記錄。
- 執行 sysprep.exe /generalize /oobe /quit /unattend
- 設定 instance_setup.ps1,以便在 VM 執行個體初次啟動時執行。
- 刪除 RDP 憑證。
- 移除儲存的永久磁碟清單。
- 啟用 RDP 和 WinRM 防火牆規則。
- 停用 Google OS 設定服務。
- 關閉執行個體。
 GCESysprep作業會記錄到 Windows 事件記錄檔和序列埠 1。 Sysprep 會寫入多個記錄檔。如何使用 GCESysprep建立 Compute Engine 映像檔:- 以管理員權限執行 - GCESysprep。- GCESysprep 
 指定圖片位置建立自訂映像檔時,您也可以指定映像檔的 Cloud Storage 位置,但不包括雙地區位置。藉由指定映像檔的儲存位置,您可以確保跨地區的備援功能,藉以遵循資料位置的法規並符合高可用性需求。 您可以自行選擇是否要使用儲存位置功能。如果未選擇位置,Compute Engine 會將映像檔儲存在最靠近映像檔來源的多地區位置。您可以從來源磁碟、映像檔、快照或儲存在 Cloud Storage 中的映像檔建立自訂映像檔。您可以使用這些映像檔,建立新的 VM 執行個體。 此功能推出前的所有現有映像檔都會保留在原來的位置。唯一的不同是您可以查看所有映像檔的所在位置。如要移動現有映像檔,則必須在所選位置重新建立檔案。 建立 Windows 映像檔您可從下列來源建立磁碟映像檔: - 永久磁碟,即使該磁碟已連接執行個體。
- 永久磁碟的快照
- 專案中的另一個映像檔
- 從另一個專案共用的映像檔
- 儲存在 Cloud Storage 中的匯入映像檔 
 主控台- 前往 Google Cloud 控制台的「Create a new image」(建立新的映像檔) 頁面。
- 指定映像檔「Name」(名稱)。
- 選擇「Source」(來源) 磁碟,這個磁碟應具有您要建立映像檔的 Windows 作業系統。
- 指定儲存映像檔的「Location」(位置)。從 [Based on source disk location (default)] (根據來源磁碟位置 (預設值)) 下拉式選單中選擇映像檔位置。例如,指定 us會將映像檔儲存在us多地區;指定us-central1則會儲存在us-central1地區。如果未選擇位置,Compute Engine 會將映像檔儲存在最靠近映像檔來源位置的多地區。
- 指定映像檔的屬性。例如,可以為映像檔指定映像檔系列名稱,以將此映像檔整理為映像檔系列的成員。
- 點選「建立」。
 gcloud使用 gcloud compute和images create,並提供您要用來建立映像檔的來源永久磁碟。您可選擇加入--force旗標以建立映像檔,即使該旗標已連結至執行中的執行個體。gcloud compute images create example-image --source-disk DISK_NAME \ --source-disk-zone ZONE \ --storage-location LOCATION \ [--force]更改下列內容: - DISK_NAME:要建立映像檔的來源磁碟名稱。
- ZONE:磁碟的可用區。
- LOCATION:選用旗標,可指定要儲存映像檔的地區或多地區。例如,指定- us會將映像檔儲存在- us多地區;指定- us-central1則會儲存在- us-central1地區。如果未選擇位置,Compute Engine 會將映像檔儲存在最靠近映像檔來源位置的多地區。
- --force:選用旗標,即使磁碟已連結至執行中的執行個體仍可建立映像檔。這個選項可能會危害映像檔的完整性。如果可以的話,請在建立映像檔之前,停止執行個體。
 當您執行此指令時, gcloud compute會根據您提供的永久磁碟建立一個新映像檔,並將該映像檔加到您的集合中。執行下列指令即可確認映像檔是否已成功建立:gcloud compute images listGo在試用這個範例之前,請先按照Go使用用戶端程式庫的 Compute Engine 快速入門中的操作說明進行設定。 詳情請參閱 Compute Engine Go API 參考說明文件。 如要向 Compute Engine 進行驗證,請設定應用程式預設憑證。 詳情請參閱「為本機開發環境設定驗證」。 Java在試用這個範例之前,請先按照Java使用用戶端程式庫的 Compute Engine 快速入門中的操作說明進行設定。 詳情請參閱 Compute Engine Java API 參考說明文件。 如要向 Compute Engine 進行驗證,請設定應用程式預設憑證。 詳情請參閱「為本機開發環境設定驗證」。 Node.jsNode.js在試用這個範例之前,請先按照Node.js使用用戶端程式庫的 Compute Engine 快速入門中的操作說明進行設定。 詳情請參閱 Compute Engine Node.js API 參考說明文件。 如要向 Compute Engine 進行驗證,請設定應用程式預設憑證。 詳情請參閱「為本機開發環境設定驗證」。 PythonPython在試用這個範例之前,請先按照Python使用用戶端程式庫的 Compute Engine 快速入門中的操作說明進行設定。 詳情請參閱 Compute Engine Python API 參考說明文件。 如要向 Compute Engine 進行驗證,請設定應用程式預設憑證。 詳情請參閱「為本機開發環境設定驗證」。 REST對 images().insert方法提出主體包含sourceDisk網址的POST要求。POST https://compute.googleapis.com/compute/v1/projects/PROJECT_ID/global/images?FORCE_OPTION { "name": "IMAGE_NAME", "sourceDisk": "zones/ZONE/disks/DISK_NAME", "storageLocations": "LOCATION", }更改下列內容: - PROJECT_ID:這項要求的專案 ID。
- FORCE_OPTION:選用旗標,即使來源磁碟已連結至執行中的執行個體,仍可建立映像檔。請在 POST 行列末端指定- forceCreate=true,即可設定此選項。這個選項可能會危害映像檔的完整性。如果可以的話,請在建立映像檔之前,停止執行個體。
- IMAGE_NAME:您要為此映像檔指定的名稱。
- ZONE:要從中建立映像檔的來源磁碟區域。
- DISK_NAME:來源磁碟的名稱。
- LOCATION:選用參數,用來選取儲存映像檔的多地區或地區。例如,指定- us會將映像檔儲存在- us多地區;指定- us-central1則會儲存在- us-central1地區。如果未選擇位置,Compute Engine 會將映像檔儲存在最靠近映像檔來源位置的多地區。
 如需更多新增映像檔的資訊,請參閱映像檔參考資料。 更新 Windows 代理程式和指令碼Compute Engine 偶爾會發佈包含最新代理程式和指令碼的新 Windows 映像檔。在處理 Windows 執行個體的啟動和關閉程序、帳戶管理以及位址管理等作業時,這些項目非常實用。 自 Windows 映像檔 v20160112版起,Windows 代理程式會透過上游發布內容自行更新。您可將disable-agent-updates執行個體中繼資料鍵值設為true以停用代理程式更新。假如您有基於較舊映像檔版本的執行個體,則可以為這些執行個體手動更新 Windows 代理程式。後續步驟除非另有註明,否則本頁面中的內容是採用創用 CC 姓名標示 4.0 授權,程式碼範例則為阿帕契 2.0 授權。詳情請參閱《Google Developers 網站政策》。Java 是 Oracle 和/或其關聯企業的註冊商標。 上次更新時間:2025-10-19 (世界標準時間)。 -