身分與存取管理
MinIO 要求用戶端針對每個新操作執行驗證和授權。
- 驗證
驗證連線用戶端身分的程序。MinIO 要求用戶端使用 AWS Signature Version 4 協定進行驗證,並支援已棄用的 Signature Version 2 協定。具體來說,用戶端必須出示有效的存取金鑰和密碼金鑰,才能存取任何 S3 或 MinIO 管理 API,例如
PUT
、GET
和DELETE
操作。- 授權
限制經過驗證的用戶端可以在部署上執行的操作和資源的程序。MinIO 使用基於原則的存取控制 (PBAC),其中每個原則都描述了一個或多個規則,概述了使用者或使用者群組的權限。在建立原則時,MinIO 支援 S3 特有的動作和條件。依預設,MinIO 會拒絕存取使用者已指派或繼承原則中未明確提及的動作或資源。
身分管理
MinIO 支援內部和外部身分管理
身分提供者 (IDP) |
描述 |
---|---|
提供內建的身分管理功能。 |
|
支援透過與 OpenID Connect (OIDC) 相容的服務管理身分。 |
|
支援使用 MinIO 驗證外掛程式擴充功能的自訂外部身分管理員。 |
|
支援透過 Active Directory 或 LDAP 服務管理身分。 |
|
支援使用 MinIO 存取管理外掛程式擴充功能的自訂外部存取管理員。 |
驗證後,MinIO 會根據驗證的身分是否授權對指定資源執行操作,來允許或拒絕用戶端請求。
存取管理
MinIO 使用基於原則的存取控制 (PBAC) 來定義經過驗證的使用者可以存取的授權動作和資源。每個原則都描述了一個或多個動作和條件,概述了使用者或使用者群組的權限。
MinIO 管理原則的建立和儲存。將原則指派給使用者或群組的程序取決於設定的身分提供者 (IDP)。
使用MinIO 內部 IDP的 MinIO 部署需要使用mc admin policy attach
命令,將使用者明確地與一個或多個原則相關聯。使用者也可以繼承其所屬群組的已附加原則。
依預設,MinIO 會拒絕存取附加或繼承原則未明確允許的動作或資源。沒有明確指派或繼承原則的使用者無法執行任何 S3 或 MinIO 管理 API 操作。
對於使用外部 IDP 的 MinIO 部署,策略的指派取決於 IDP 的選擇
MinIO 會檢查 JSON Web Token (JWT) 宣告(預設為 MinIO 不支援將 OIDC 使用者身分指派給群組。IDP 管理員必須改為將所有必要的策略指派給使用者的策略宣告。 請參閱外部管理身分的存取控制以取得更多資訊。 |
|
MinIO 會檢查名稱與已驗證的 AD/LDAP 使用者的辨別名稱 (DN) 相符的策略。 MinIO 也支援查詢已驗證的 AD/LDAP 使用者的群組成員資格。MinIO 會指派名稱與每個傳回群組的 DN 相符的任何策略。 如果沒有任何策略與使用者 DN *或* 任何使用者的群組 DN 相符,則使用者無法在 MinIO 部署上執行任何操作。 請參閱外部管理身分的存取控制以取得更多資訊。 |
MinIO PBAC 的建構目的是為了與 AWS IAM 策略語法、結構和行為相容。MinIO 文件盡力涵蓋 IAM 特有的行為和功能。請參考 IAM 文件,以取得有關 IAM、IAM 策略或 IAM JSON 語法的更完整文件。
拒絕
會覆蓋 允許
MinIO 遵循 AWS IAM 策略評估規則,其中 拒絕
規則會覆蓋相同動作/資源上的 允許
規則。例如,如果使用者具有明確指派的策略,其中包含對某個動作/資源的 允許
規則,而其群組之一具有指派的策略,其中包含對該動作/資源的 拒絕
規則,則 MinIO 將僅套用 拒絕
規則。
有關 IAM 策略評估邏輯的更多資訊,請參閱 IAM 文件中的判斷是否允許或拒絕帳戶中的請求。