設定 Blob 層
作業 Set Blob Tier
會在 Blob 上設定存取層。 在進階記憶體帳戶中的分頁 Blob 和 Blob 記憶體或一般用途 v2 帳戶中的區塊 Blob 上,允許此作業。 進階分頁 Blob 的層 (P4
P6
P40
///P60
/P10
///P20
P15
/P30
P50
) 決定 Blob 允許的大小、IOPS 和頻寬。 區塊 Blob 的層會Hot
Cool
/Cold
Archive
//決定記憶體類型。 這項作業不會更新 Blob 的 ETag。
如需區塊 Blob 層級階層處理的詳細資訊,請參閱 經常性存取、非經常性存取和封存儲存層。
要求
您可以建構 Set Blob Tier
要求,如下所示。 建議您使用 HTTPS。 將 myaccount 取代為您的記憶體帳戶名稱,並將 myblob 取代為要變更階層的 Blob 名稱。
方法 | 要求 URI | HTTP 版本 |
---|---|---|
PUT |
https://myaccount.blob.core.windows.net/mycontainer/myblob?comp=tier |
HTTP/1.1 |
URI 參數
您可以在要求 URI 上指定下列其他參數:
參數 | 描述 |
---|---|
snapshot |
選擇性。 快照集參數是不透明的 DateTime 值,當存在時,會指定要設定階層的 Blob 快照集。 如需使用 Blob 快照集的詳細資訊,請參閱 Create Blob 的快照集 |
versionid |
選擇性版本 2019-12-12 和更新版本。 參數 versionid 是不透明的 DateTime 值,當存在時,會指定要設定階層的 Blob 版本。 |
timeout |
選擇性。
timeout 參數以秒為單位。 如需詳細資訊,請參閱 設定 Blob 記憶體作業的逾時。 |
要求標頭
下表說明必要的和選擇性要求標頭:
要求標頭 | 描述 |
---|---|
Authorization |
必要。 指定授權配置、記憶體帳戶名稱和簽章。 如需詳細資訊,請參閱授權對 Azure 儲存體提出要求。 |
Date 或 x-ms-date |
必要。 指定要求的「國際標準時間」(UTC)。 如需詳細資訊,請參閱授權對 Azure 儲存體提出要求。 |
x-ms-access-tier |
必要。 指出在 Blob 上設定的階層。 如需允許的進階分頁 Blob 層清單,請參閱 VM 的高效能 進階儲存體 和受控磁碟。 對於 Blob 記憶體或一般用途 v2 帳戶,有效值為 Hot 、 Cool 、 Cold 和 Archive 。
注意:Cold 2021-12-02 版和更新版本支持階層。 如需標準 Blob 帳戶 Blob 層級階層處理的詳細資訊 ,請參閱經常性存取、非經常性存取和封存儲存層。 |
x-ms-version |
所有已授權要求都需要。 指定用於這個要求的作業版本。 如需詳細資訊,請參閱 Azure 記憶體服務的版本設定。 |
x-ms-client-request-id |
選擇性。 提供客戶端產生的不透明值,其中包含啟用記憶體分析記錄時,分析記錄中記錄的 1-kB 字元限制。 強烈建議使用此標頭來將用戶端活動與伺服器接收的要求相互關聯。 如需詳細資訊,請參閱關於 儲存體分析 記錄。 |
x-ms-rehydrate-priority |
選擇性。 表示要解除凍結封存 Blob 的優先順序。 支援區塊 Blob 版本 2019-02-02 和更新版本。 有效值為 High /Standard 。 在 Blob 上只能針對 2020-06-12 之前的版本設定優先順序一次;後續要求將會忽略此標頭。 預設優先權設定為 Standard 。從 2020-06-12 版開始,在先前設定後可以更新解除凍結優先順序。 您可以將這個標頭設定設為 High ,並將設定x-ms-access-tier 為與先前設定相同的值,將優先順序設定從 Standard High 變更為 。 優先權設定無法從 High 降低為 Standard 。 |
只有在符合指定的條件時,此作業也支援使用條件標頭將 Blob 分層。 如需詳細資訊,請參閱 指定 Blob 記憶體作業的條件式標頭。
要求本文
無。
回應
回應包括 HTTP 狀態碼和一組回應標頭。
狀態碼
成功作業會傳回狀態代碼 200 (OK) 如果新層立即生效,或狀態代碼 202 (如果轉換至新層擱置,則為已接受) 狀態代碼。
針對進階記憶體帳戶,分頁 Blob 作業會傳回狀態代碼 200 (OK) 。
針對區塊 Blob,會根據 Blob 的目前和要求層傳回的 HTTP 狀態代碼,如下表所述:
層 | 設定為經常性存取層 | 設定為非經常性存取層 | 設定為冷層 | 設定為封存層 |
---|---|---|---|---|
經常性存取層中的 Blob | 200 | 200 | 200 | 200 |
非經常性存取層中的 Blob | 200 | 200 | 200 | 200 |
冷層中的 Blob | 200 | 200 | 200 | 200 |
封存層中的 Blob | 202 | 202 | 202 | 200 |
封存層中的 Blob,解除凍結為經常性存取 | 202 | 409 | 409 | 409 |
封存層中的 Blob,解除凍結為非經常性存取 | 409 | 202 | 409 | 409 |
封存層中的 Blob,解除凍結為冷 | 409 | 409 | 202 | 409 |
如需狀態代碼的詳細資訊,請參閱 狀態和錯誤碼。
回應標頭
這項作業的回應包括下列標頭。 回應也可能包括其他標準 HTTP 標頭。 所有標準標頭都符合 HTTP/1.1 通訊協議規格。
回應標頭 | 描述 |
---|---|
x-ms-request-id |
可唯一識別已提出的要求,並可用來對要求進行疑難解答。 如需詳細資訊,請參閱 針對 API 作業進行疑難解答。 |
x-ms-version |
用來執行要求的 Blob 記憶體版本。 對 2009-09-19 及更新版本提出要求會傳回此標頭。 |
x-ms-client-request-id |
可用來針對要求和對應的回應進行疑難解答。 如果此標頭存在於要求中,則此標頭的值等於標頭的值 x-ms-client-request-id ,且值不包含超過 1,024 個可見的 ASCII 字元。
x-ms-client-request-id 如果要求中沒有標頭,則不會出現在回應中。 |
授權
在 Azure 記憶體中呼叫任何數據存取作業時,需要授權。 您可以授權 Set Blob Tier
作業,如下所示。
重要
Microsoft 建議使用 Microsoft Entra ID 搭配受控識別來授權對 Azure 記憶體的要求。 相較於共用密鑰授權,Microsoft Entra ID 提供較佳的安全性和方便使用。
Azure 記憶體支援使用 Microsoft Entra ID 來授權 Blob 數據的要求。 使用 Microsoft Entra ID,您可以使用 Azure 角色型存取控制 (Azure RBAC) ,將許可權授與安全性主體。 安全性主體可能是使用者、群組、應用程式服務主體或 Azure 受控識別。 安全性主體是由 Microsoft Entra ID 驗證,以傳回 OAuth 2.0 令牌。 權杖接著可以用來授權對 Blob 服務的要求。
若要深入瞭解使用 Microsoft Entra ID 授權,請參閱使用 Microsoft Entra ID 授權 Blob 的存取權。
權限
以下是 Microsoft Entra 使用者、群組、受控識別或服務主體呼叫Set Blob Tier
作業所需的 RBAC 動作,以及包含此動作的最低特殊許可權內建 Azure RBAC 角色:
- Azure RBAC 動作:Microsoft.Storage/storageAccounts/blobServices/containers/blobs/write
- 最低特殊許可權內建角色:記憶體 Blob 數據參與者
若要深入瞭解如何使用 Azure RBAC 指派角色,請參閱 指派 Azure 角色以存取 Blob 數據。
備註
在進階帳戶中設定分頁 Blob 的 Blob 層具有下列限制:
- 新的 Blob 層不能低於現有的 Blob 層。
- 新的 Blob 層應該能夠容納 Blob 的內容長度。 如需階層及其允許的內容長度清單,請參閱 VM 的高效能進階記憶體和受控磁碟。
在 Blob 記憶體或一般用途 v2 帳戶上設定區塊 Blob 的層有下列限制:
- 從 REST 2019-12-12-12 版起,允許在快照集上設定層。
- 分層至
archive
的快照集無法重新凍結至快照集。 也就是說,快照集無法回到hot
或cool
層。 從快照集或版本擷取數據的唯一archive
方法是將它複製到新的 Blob。 - 如果版本是根 Blob,它可以重新凍結回
hot
或cool
。 - 不允許將處於狀態的
archive
快照集或版本升級為根目錄。 - 啟用版本控制時,當根 Blob 處於解除凍結擱置狀態時,刪除根 Blob 將會導致取消凍結,而且版本會處於
archive
狀態。 - 如果 Blob 處於解除凍結和虛刪除狀態時遭到覆寫,則會導致解除凍結,且虛刪除快照集的版本會處於
archive
狀態。
支援層的清單不受要求版本限制,未來可能會新增層。
注意
如需區塊 Blob 層級階層處理的詳細資訊,請參閱 經常性存取、非經常性存取和封存儲存層。
計費
定價要求可能源自使用 Blob 記憶體 API 的用戶端,無論是直接透過 Blob 記憶體 REST API,還是來自 Azure 記憶體用戶端連結庫。 這些要求會累算每個交易的費用。 交易類型會影響帳戶的收費方式。 例如,讀取交易會累算到與寫入交易不同的計費類別。 下表根據記憶體帳戶類型顯示要求的計費類別 Set Blob Tier
:
作業 | 儲存體帳戶類型 | 計費類別 |
---|---|---|
將 Blob 層 (層向下設定) | 進階區塊 Blob 標準一般用途 v2 |
寫入作業 |
設定 Blob 層 (層上層) | 進階區塊 Blob 標準一般用途 v2 |
讀取作業 |
若要瞭解指定計費類別的定價,請參閱 Azure Blob 儲存體 定價。