如何使用ThinkSystem伺服器的 XCC Redfish REST API 更新系統韌體

如何使用ThinkSystem伺服器的 XCC Redfish REST API 更新系統韌體

如何使用ThinkSystem伺服器的 XCC Redfish REST API 更新系統韌體

這份文件為翻譯程式自動翻譯結果,請點選以下連結流灠英文版文件內容。

描述

Lenovo XClarity Controller (XCC) 為業界標準 Redfish 可擴展平台管理 API 提供支持,該 API 可用於從 XCC 外部運行的應用程式存取 XCC 資料和服務。 Redfish 使用 RESTful 介面語意學和 JSON 資源負載透過基於 Web 的協定執行系統管理。

本文介紹使用 XCC Redfish REST API 更新系統韌體的流程。

本文將使用以下 HTTP 方法:

  • GET:讀取請求-用於請求指定的資源或集合來檢查數據
  • POST:動作請求-用於發起作業或建立資源

適用系統

ThinkSystem (HR330A、HR350A、HR630X、HR650X 除外)、SR645、SR665

先決條件

  • 您的工作站或筆記型電腦上必須安裝 Redfish 用戶端。
  • 紅魚客戶:
  • Chrome:Postman、Talend API 測試器
  • 火狐:REST客戶端
  • 工作站或筆記型電腦必須能夠直接透過網路存取目標伺服器上的 XCC。

程式

請依照以下步驟,使用 XCC Redfish API 方法更新系統韌體層級。

下載所需的韌體包

  1. Lenovo支援頁面下載適合您的機器的韌體包。
  2. 解壓縮檔案並將內容複製到指定資料夾。

檢索已安裝的韌體版本

  1. 若要存取韌體清單集合中的屬性,請開啟 postman,選擇GET方法 ,然後輸入下列要求的 URL :https:// BMCIP /redfish/v1/UpdateService/FirmwareInventory
  2. 授權標籤中,從類型選單中選擇基本驗證,然後輸入 BMC 憑證 。點選發送

存貨

注意:每個請求都需要此授權步驟。

回應範例

如果請求成功,會傳回類似如下的訊息體:

 { "成員": [ { "@odata.id": "/redfish/v1/UpdateService/FirmwareInventory/BMC-Primary" }, { "@odata.id": "/redfish/v1/UpdateService/FirmwareInventory/BMC-備份" }, { "@odata.id": "/redfish/v1/UpdateService/FirmwareInventory/UEFI" }, { "@odata.id": "/redfish/v1/UpdateService/FirmwareInventory/LXPM" }, { " @odata.id": "/redfish/v1/UpdateService/FirmwareInventory/LXPMWindowsDriver" }, { "@odata.id": "/redfish/v1/UpdateService/FirmwareInventory/LXPMLinuxDriver" }, { "@odata.id": "/redfish/v1/UpdateService/FirmwareInventory/Ob_1.Bundle" }, { "@odata.id": "/redfish/v1/UpdateService/FirmwareInventory/Slot_4.Bundle" }, { "@odata.id": "/ redfish/v1/UpdateService/FirmwareInventory/Ob_5.Bundle" }, { "@odata.id": "/redfish/v1/UpdateService/FirmwareInventory/Ob_4.Bundle" }, { "@odata.id": "/redfish/ v1/UpdateService/FirmwareInventory/Ob_1.1" }, { "@odata.id": "/redfish/v1/UpdateService/FirmwareInventory/Ob_1.2" }, { "@odata.id": "/redfish/v1/ UpdateService/FirmwareInventory/Slot_4.1" }, { "@odata.id": "/redfish/v1/UpdateService/FirmwareInventory/Disk1" }, { "@odata.id": "/redfish/v1/UpdateService/FirmwareInventory/磁碟2" }, { "@odata.id": "/redfish/v1/UpdateService/FirmwareInventory/Disk3" }, { "@odata.id": "/redfish/v1/UpdateService/FirmwareInventory/Disk4" }, { " @odata.id": "/redfish/v1/UpdateService/FirmwareInventory/Disk5" }, { "@odata.id": "/redfish/v1/UpdateService/FirmwareInventory/Disk6" }, { "@odata.id" : "/redfish/v1/UpdateService/FirmwareInventory/PSU1" } ], "@odata.type": "#SoftwareInventoryCollection.SoftwareInventoryCollection", "@odata.id": "/redfish/v1/UpdateService/FirmwareInventory", "MrmwareInventory", "MrmwareInvenware @ odata.count":20,"@odata.etag":"\"af76d20eb1af2e197f855\"","名稱":"SoftwareInventoryCollection","描述":"韌體庫存集合。 }
  1. 從成員清單的輸出中,找到您要查詢的系統韌體端點 - 例如/redfish/v1/UpdateService/FirmwareInventory/UEFI 。將其輸入 URL 欄位以取得 UEFI 資訊。
 { "ReleaseDate": "2020-09-18T00:00:00Z", "RelatedItem": [ { "@odata.id": "/redfish/v1/Systems/1/ Bios " } ], "Id": " UEFI", "Status": { "HealthRollup": "OK", "Health": "OK", "State": "Enabled" }, "Manufacturer": " Lenovo ", "Name": "韌體:UEFI" ,“版本”:“60N-2.71”,“SoftwareId”:“UEFI-IVE1-6”,“RelatedItem@odata.count”:1,“@odata.type”:“#SoftwareInventory.v1_2_3.SoftwareInventory”,“ @odata.id": "/redfish/v1/UpdateService/FirmwareInventory/UEFI", "可更新": true, "@odata.etag": "\"3d193e9f3c0c2725df0\"", "LowestSupportedVersion": null, "描述" : “UEFI韌體資訊。” }

在上面的回應資料中,安裝的 UEFI 為60N-2.71 ,軟體 ID 為UEFI-IVE1-1.6

應用程式韌體更新

使用 POST 方法應用UEFIXCC 更新

UEFI 更新

  1. 選擇POST方法,然後輸入以下請求的 URL: https:// BMCIP /fwupdate
  2. POST操作的「內文」標籤中,選擇「二進位」 ,然後選擇要更新的韌體映像。

韌體更新

  1. 按一下“發送”

傳送

  1. 如果請求成功,將顯示回應代碼狀態202 Accepted 。訊息正文將類似於以下範例:

202 已接受

在上面的回應範例中, /redfish/v1/TaskService/Tasks/00fc5d1b-f3da-469a-a4b0-007e91baa55f是剛剛建立的新任務。您可以使用Get方法透過任務ID查詢更新狀態。

請求的網址

https:// BMCIP /redfish/v1/TaskService/Task/ ID

回應範例

任務完成

任務2

  1. 重新啟動伺服器並再次執行韌體清單。 BIOS版本將已更新。
    您也可以使用POST方法來執行系統重新啟動。

請求的網址

https: //BMCIP/redfish/v1/Systems/1/Actions/ComputerSystem.Reset

POST 操作請求的正文

{“ResetType”:“GracefulRestart”}
# 系統重置類型的可能值可以是On/ForceOff/GracefulShutdown/GracefulRestart/ForceRestart/Nmu/ForceOn
權力行動

回應範例

將傳回以下 JSON 回應:

沒有任何

[回頂端]

XCC更新

  1. 選擇POST方法,然後輸入以下請求的 URL: https:// BMCIP /fwupdate
  2. POST操作的「內文」標籤中,選擇「二進位」 ,然後選擇要更新的韌體映像。

韌體更新

  1. 按一下“發送”

XCC更新

  1. 如果請求成功,將顯示回應代碼狀態202 Accepted 。訊息正文將類似於以下範例:

已套用 XCC 更新

在上面的回應範例中, /redfish/v1/TaskService/Tasks/d9674179-39e2-4842-8cbe-5d2ce477e49b是剛剛建立的新任務。您可以使用Get方法透過任務ID查詢更新狀態。

請求的網址

https:// BMCIP /redfish/v1/TaskService/Task/ID

回應範例

XCC更新完成

XCC更新完成2

  1. 重新啟動伺服器並再次執行韌體清單。 XCC 版本將已更新。
    您也可以使用POST方法重新啟動XCC。

請求的網址

https://BMCIP/redfish/v1/Managers/1/Actions/Manager.Reset

POST 操作請求的正文

{“ResetType”:“GracefulRestart”}
# XCC重置類型的可能值可以是GracefulRestart/ForceRestart

回應範例

將傳回以下 JSON 回應:

沒有任何

[回頂端]

影片

附加資訊

相關文章

文件ID:HT511484
原始發布日期:11/20/2020
Last Modified Date:08/26/2024