文件

物件刪除

概觀

本頁總結了 DELETE 操作如何根據包含物件的儲存貯體設定來影響物件。

下列因素的任何組合都可能影響 DELETE 操作的運作方式

權限

MinIO 使用 基於政策的存取控制系統進行存取管理。使用者或服務帳戶必須提供正確的政策動作和條件,以允許對儲存貯體和物件執行 DELETE

未版本控制的物件

當對未啟用版本控制的儲存貯體中的物件執行 DELETE 操作時,該操作非常簡單。在驗證使用者或服務帳戶有權執行 DELETE 操作後,MinIO 會永久移除該物件。

請求刪除動作的使用者或服務帳戶必須具有儲存貯體和物件的 s3:DeleteObject 動作權限。

已版本控制的物件

當物件被版本化時,DELETE 操作的運作方式會有所不同。

使用者或服務帳戶必須擁有針對儲存桶和物件的 s3:DeleteObjectVersion 動作權限。

目前版本上的刪除操作

對已版本化的物件執行未指定版本 UUID 的 DELETE 操作,會導致建立一個 DeleteMarker 並放置在物件的 head (頭部)。

在這種情況下,MinIO 實際上並不會從磁碟中移除物件或其任何版本。物件的所有現有版本仍可透過指定版本的 UUID 來存取。當 DeleteMarker 是物件的頭部時,MinIO 不會為未指定版本 ID 的 GET 請求提供物件。相反地,MinIO 會返回類似 404 的回應。

您可以使用 mc ls --versions 找到物件版本的 UUID。

要從磁碟機中移除物件的目前版本,請找到該版本的 UUID,然後使用 mc rm --version-id=UUID ... 刪除目前版本。在這種情況下,物件緊接的前一個版本會成為物件的目前版本,並用於服務未指定 UUID 的物件 GET 請求。

警告

在 DELETE 操作中指定 version-id 是不可逆的。MinIO 會從磁碟機中移除指定的版本,且無法還原。

先前版本上的刪除操作

要刪除物件的先前版本,請指定該版本的 UUID。您可以使用 mc ls --versions 檢索版本 UUID。當 DELETE 請求指定了 version-id,並且使用者具有刪除物件版本的正確權限時,MinIO 會從磁碟機中永久移除指定的版本。

警告

在 DELETE 操作中指定 version-id 是不可逆的。MinIO 會從磁碟機中移除指定的版本,且無法還原。

刪除所有版本

使用 mc rm --versions 刪除物件的所有版本。這是不可逆的。

生命週期管理過期

您可以定義一個或多個生命週期管理過期規則,以便在達到特定版本號或經過一段時間後,讓物件過期。當存在的版本多於規則指定的數量,或版本早於指定的期限時,MinIO 會從磁碟機中永久移除該物件版本。

這些規則依賴掃描器來處理儲存桶上的規則。掃描器以較低的優先級連續程序運作,其中 READWRITE 動作具有優先權。因此,符合過期要求的物件版本可能不會立即從 MinIO 中移除。

有關掃描器如何運作以及配置選項的詳細資訊,請參閱掃描器頁面。

DeleteMarkers 本身是物件。生命週期規則可以移除 DeleteMarkers,這些 DeleteMarkers 是其物件唯一剩餘的版本。

在 MinIO 版本中變更: RELEASE.2024-05-01T01-11-10Z

使用 JSON,生命週期規則可以在指定的期限天數後移除已刪除物件的所有版本。

保留的物件

MinIO 會保護受鎖定規則約束的物件,使其免於被覆寫或刪除。這些規則要求物件必須保留到規則過期或被移除為止。

對沒有指定版本的鎖定物件執行 DELETE 操作,會建立物件的 DeleteMarker。但是,物件版本本身會根據鎖定要求保留。

指定物件版本的 DELETE 操作會受保留規則約束。MinIO 會保護受鎖定約束的物件版本,使其免於被覆寫或刪除,直到鎖定過期或被移除為止。

複製的物件

複製會將物件從一個位置複製到另一個位置。MinIO 支援儲存桶級別或叢集(「站點」)級別的複製。

刪除操作可能會或可能不會複製,具體取決於複製類型以及複製的配置方式。

站點複製

對於啟用多站點複製的叢集,MinIO 會將在任何叢集上執行的所有 delete 操作複製到對等群組中的其他每個叢集。

任何單個對等節點上的刪除行為都遵循與任何 MinIO 部署相同的流程。

儲存桶複製

透過儲存桶複製,MinIO 支援在來源儲存桶和設定的遠端儲存桶之間複製刪除操作。MinIO 會同步刪除特定物件版本新的 刪除標記。刪除操作複製使用與所有其他複製操作相同的複製流程

MinIO 需要明確啟用版本化刪除和刪除標記複製。使用 mc replicate add --replicate 欄位來指定 deletedelete-marker 或兩者皆指定,以分別啟用版本化刪除和刪除標記複製。要同時啟用兩者,請使用逗號分隔符號指定這兩個字串:delete,delete-marker

對於刪除標記複製,MinIO 會在刪除操作建立刪除標記後開始複製流程。MinIO 使用 X-Minio-Replication-DeleteMarker-Status 中繼資料欄位來追蹤刪除標記複製狀態。在主動-主動複製配置中,如果兩個叢集同時為一個物件建立刪除標記,如果一個或兩個叢集在複製事件同步之前關閉,則 MinIO 可能會產生重複的刪除標記。

為了複製特定物件版本的刪除操作,MinIO 會將物件版本標記為 PENDING,直到複製完成。一旦遠端目標刪除該物件版本,MinIO 會刪除來源上的物件版本。雖然此流程確保近乎同步的版本刪除,但可能會導致列表操作在初始刪除操作後返回物件版本。MinIO 使用 X-Minio-Replication-Delete-Status 來追蹤刪除版本複製狀態。

MinIO 僅複製明確的用戶端驅動的刪除操作。MinIO 不會複製由生命週期管理過期規則刪除的物件。對於主動-主動配置,請在所有複製儲存桶上設定相同的過期規則,以確保一致地應用物件過期。