CEPH RGW 支持 Bucket 的 S3 策略语言,但又不完全类似于 S3 的策略,因为 S3 中策略是基于 AWS 的,某些属性在 CEPH 中并不存在,下面就解开 RGW 关于桶策略的配置。
Bucket Policy (桶策略,下文中统称为 BP) 是对象存储中的管理权限和对象存储访问的机制。
Policy Language 的组成
BP 的格式采用了 JSON 语言,也就是 PL 是基于 JSON 的一种策略语言,他的格式主要为几个元素
|
|
该结构由 ==一个== Version (表示当前版本) 和 ==一个或多个== Statement 数组组成,这些数组定义了希望应用的策略。每个语句数组中都有Effect, Principal, Action, Resource 和可选的 Condition 元素。
Effect
Effect 部分定义是一个动作,表示是否 Allow 或 Deny 指定资源的访问
|
|
Principal
Principal 部分定义了策略应用的 “用户” 或 “实体” (entity) 或 “服务” 等,这里是按照 aws 中子源固定语法组成,当然在 CEPH 中不存在这些资源,那么相对的也是一种固定格式
AWS 将用户分为了三类:
- AWS 账户 (AWS ACCOUNT)
- IAM 用户 (IAM USER)
- 匿名用户 (anonymous)
语法如下:
|
|
AWS Account
对于该类 “实体”,采用了下面的语法
|
|
示例
|
|
或
|
|
IAM USER
AWS IAM (AWS Identity and Access Management) ,是 AWS 中用户管理的一种方式,指定 “WHO”, “CAN ACCESS”, “WAHT” (AWS 中的服务和资源、集中管理精细权限)
对于该类 “实体”,采用了下面的语法
|
|
匿名用户
匿名用户就是指对 ”每个人都授予的权限“,可以使用 通配符 ("*") ,这类权限的配置对象是 ”存储桶中的所有对象均可公开访问“
|
|
或者
|
|
上面两类用户实际上权限分散的还是不一样,主要区别如下:
"Principal": "*"
并且Effect: Allow
那么将允许任何人访问该资源。- 如果
Effect: Allow
并且"Principal" : { "AWS" : "*" }
,允许 AWS 账户中的 IAM User, Root User.. 访问该资源(通常 不涉及到 CEPH)
Action
Action 部分定义了 ”对策略授予 (删除) 的权限”。这些操作包括 list bucket 等的功能;需要注意的是,这里 AWS S3 与 CEPH RGW 中定义的权限又不相同,对于 CEPH 中 Action 的权限集合,可以参考 [1]
Resource
Action 部分定义了 “应用于对象存储资源” 例如存储桶和对象,这里的资源类型也是一种基于 aws 资源的固定格式,而在 CEPH 中不存在的部分直接为空,例如:
- Bucket resources:
"arn:aws:s3:::[bucket]"
- 应用所存储同种所有对象或部分对象:
"arn:aws:s3:::[bucket]/[object]"
在上面的策略语言中,将 [bucket] 替换为存储桶的标签,将 [object] 替换为指定所有对象的通配符值 (*) 或对象的路径和名称。
例如下面几个示例
将策略应用到所有对象:
|
|
指定目录中的所有对象:
|
|
特殊对象
|
|
桶策略示例
允许任何人查看和下载 bucket 中的对象
|
|
授予指定帐户只能对指定目录的访问权限
|
|
允许特定 IP 的访问
上面在 “策略语言” 中没有提到一个可选参数 “Condition”,这在 CEPH 中也是支持的,通过使用 “Condition” 您可以选择允许或拒绝来自指定 IP 地址或范围的流量。
下面的示例仅允许来自指定 IP 地址的所有流量:
|
|
目前 CEPH 支持的 Condition 字段的值为,参考与 [1]
- aws:CurrentTime
- aws:EpochTime
- aws:PrincipalType
- aws:Referer
- aws:SecureTransport
- aws:SourceIp
- aws:UserAgent
- aws:username
应用桶策略
桶策略的应用只能通过 s3cmd
命令执行,radosgw-admin 命令并不可以应用,所以要想应用前,需要准备好对应的对象存储相关的配置
语法
|
|
例如,将文件 “policy.json” 中定义的策略应用到名为 “example-bucket” 的存储桶中
|
|
Reference
[1] LIMITATIONS
[2] Guides - Define Access and Permissions using Bucket Policies