权限管理
如果您需要对华为云上购买的CDN(Content Delivery Network,内容分发网络)资源,为企业中的员工设置不同的访问权限,以达到不同员工之间的权限隔离,您可以使用统一身份认证服务(Identity and Access Management,简称IAM)进行精细的权限管理。该服务提供用户身份认证、权限分配、访问控制等功能,可以帮助您安全的控制华为云资源的访问。如果华为账号已经能满足您的要求,不需要通过IAM对用户进行权限管理,您可以跳过本章节,不影响您使用CDN服务的其它功能。
IAM是华为云提供权限管理的基础服务,无需付费即可使用,您只需要为您账号中的资源进行付费。
通过IAM,您可以通过授权控制他们对华为云资源的访问范围。例如您的员工中有负责软件开发的人员,您希望他们拥有CDN的使用权限,但是不希望他们拥有删除CDN等高危操作的权限,那么您可以使用IAM进行权限分配,通过授予用户仅能使用CDN,但是不允许删除CDN的权限,控制他们对CDN资源的使用范围。
目前IAM支持两类授权,一类是角色与策略授权,另一类为身份策略授权。
两者有如下的区别和关系:
| 名称 | 核心关系 | 涉及的权限 | 授权方式 | 适用场景 |
|---|---|---|---|---|
| 角色与策略授权 | 用户-权限-授权范围 |
| 为主体授予角色或策略 | 核心关系为“用户-权限-授权范围”,每个用户根据所需权限和所需授权范围进行授权,无法直接给用户授权,需要维护更多的用户组,且支持的条件键较少,难以满足细粒度精确权限控制需求,更适用于对细粒度权限管控要求较低的中小企业用户。 |
| 身份策略授权 | 用户-策略 |
|
| 核心关系为“用户-策略”,管理员可根据业务需求定制不同的访问控制策略,能够做到更细粒度更灵活的权限控制,新增资源时,对比角色与策略授权,基于身份策略的授权模型可以更快速地直接给用户授权,灵活性更强,更方便,但相对应的,整体权限管控模型构建更加复杂,对相关人员专业能力要求更高,因此更适用于中大型企业。 |
例如:如果需要对IAM用户授予可以创建华北-北京四区域的ECS和华南-广州区域的OBS的权限,基于角色与策略授权的场景中,管理员需要创建两个自定义策略,并且为IAM用户同时授予这两个自定义策略才可以实现权限控制。在基于身份策略授权的场景中,管理员仅需要创建一个自定义身份策略,在身份策略中通过条件键“g:RequestedRegion”的配置即可达到身份策略对于授权区域的控制。将身份策略附加主体或为主体授予该身份策略即可获得相应权限,权限配置方式更细粒度更灵活。
两种授权场景下的策略/身份策略、授权项等并不互通,推荐使用身份策略进行授权。角色与策略权限管理和身份策略权限管理分别介绍两种模型的系统权限。
关于IAM的详细介绍,请参见IAM产品介绍。
角色与策略权限管理
CDN服务支持角色与策略授权。默认情况下,管理员创建的IAM用户没有任何权限,需要将其加入用户组,并给用户组授予策略或角色,才能使得用户组中的用户获得对应的权限,这一过程称为授权。授权后,用户就可以基于被授予的权限对云服务进行操作。
CDN部署时不区分物理区域,为全局级服务。授权时,在全局级服务中设置权限,访问CDN时,不需要切换区域。
如表1所示,包括了CDN的所有系统权限。角色与策略授权场景的系统策略与身份策略授权场景的并不互通。
| 系统角色/策略名称 | 描述 | 类别 | 依赖关系 |
|---|---|---|---|
| CDN LogsReadOnlyAccess | 具有CDN日志服务只读权限。 | 系统策略 | 无 |
| CDN RefreshAndPreheatAccess | 具有CDN刷新预热权限。 | 系统策略 | 无 |
| CDN Administrator | 具有CDN的所有执行权限。 | 系统角色 | 无 |
| CDN ReadOnlyAccess | 具有CDN所有服务读权限。 | 系统策略 | 无 |
| CDN FullAccess | 具有CDN的所有权限 | 系统策略 | 无 |
| CDN StatisticsReadOnlyAccess | 具有CDN统计服务只读权限。 | 系统策略 | 无 |
| CDN DomainConfiguration | 具有CDN加速域名的配置权限。 | 系统策略 | 无 |
| CDN DomainReadOnlyAccess | 具有CDN加速域名信息的只读权限。 | 系统策略 | 无 |
表3列出了CDN常用操作与系统权限的授权关系,您可以参照该表选择合适的系统权限。
| 操作 | CDN Administrator | CDN ReadOnlyAccess | CDN StatisticsReadOnlyAccess | CDN LogsReadOnlyAccess | CDN DomainConfiguration | CDN RefreshAndPreheatAccess | CDN FullAccess | CDN DomainReadOnlyAccess |
|---|---|---|---|---|---|---|---|---|
| 查询计费模式 | √ | √ | √ | √ | √ | √ | √ | √ |
| 创建或修改计费模式 | √ | x | x | x | x | x | √ | x |
| 查询域名统计数据 | √ | √ | √ | x | x | x | √ | x |
| 日志查询 | √ | √ | x | √ | x | x | √ | x |
| 查询域名所有配置 | √ | √ | x | x | √ | x | √ | √ |
| 修改域名所有配置 | √ | x | x | x | √ | x | √ | x |
| 创建加速域名 | √ | x | x | x | √ | x | √ | x |
| 查询账户信息 | √ | √ | x | x | √ | x | √ | √ |
| 修改账户信息 | √ | x | x | x | √ | x | √ | √ |
不能单独配置CDN DomainConfiguration和CDN RefreshAndPreheatAccess权限,如果想配置这两个权限,请同时配置CDN DomainReadOnlyAccess权限,否则会造成所有域名不可见导致无法进行域名配置和刷新预热配置。
CDN控制台功能依赖的角色或策略
CDN对其他云服务有诸多依赖关系,因此在您开启IAM系统策略授权后,在CDN Console控制台的各项功能需要配置相应的服务权限后才能正常查看或使用,前提条件如下:
- 依赖服务的权限配置均基于您已设置了IAM系统策略授权的CDN FullAccess或CDN ReadOnlyAccess策略权限。
如果IAM用户需要在CDN Console控制台拥有相应功能的查看或使用权限,请确认已经对该用户所在的用户组设置了CDN Administrator、CDN FullAccess或CDN ReadOnlyAccess策略的集群权限,再按如下表4增加依赖服务的权限。
| Console控制台功能 | 依赖服务 | 需配置角色/策略 |
|---|---|---|
| 统一身份认证服务 IAM |
|
| 源站配置
| 对象存储服务 OBS |
|
| SCM证书 | 云证书与管理服务 CCM |
|
| 按照标签筛选域名 | 标签管理服务 TMS | 查询预定义标签:tms:predefineTags:list |
| 企业项目 | 企业管理 |
|
身份策略权限管理
CDN服务支持身份策略授权。如表5所示,包括了CDN身份策略中的所有系统身份策略。身份策略授权场景的系统身份策略与角色与策略授权场景的并不互通。
| 系统策略名称 | 描述 | 策略类别 |
|---|---|---|
| CDNAdministratorPolicy | 对CDN的所有执行权限。 | 系统身份策略 |
| CDNReadOnlyPolicy | 对CDN所有服务具有读权限。 | 系统身份策略 |
| CDNStatisticsReadOnlyPolicy | 对CDN统计服务只读权限。 | 系统身份策略 |
| CDNLogsReadOnlyPolicy | 对CDN日志服务只读权限。 | 系统身份策略 |
| CDNDomainConfigurationPolicy | 对CDN加速域名的配置权限。 | 系统身份策略 |
| CDNRefreshAndPreheatPolicy | CDN刷新预热权限。 | 系统身份策略 |
| CDNFullPolicy | 对CDN的所有执行权限。 | 系统身份策略 |
| CDNDomainReadOnlyPolicy | 对CDN加速域名信息的只读权限。 | 系统身份策略 |
| CDNChargeConfigurationPolicy | 具有CDN计费服务开通、修改、查询计费模式权限。 | 系统身份策略 |
表6列出了CDN常用操作与系统身份策略的授权关系,您可以参照该表选择合适的系统身份策略。
| 操作 | CDNAdministratorPolicy | CDNReadOnlyPolicy | CDNStatisticsReadOnlyPolicy | CDNLogsReadOnlyPolicy | CDNDomainConfigurationPolicy | CDNRefreshAndPreheatPolicy | CDNFullPolicy | CDNDomainReadOnlyPolicy | CDNChargeConfigurationPolicy |
|---|---|---|---|---|---|---|---|---|---|
| 查询计费模式 | √ | √ | √ | √ | √ | √ | √ | √ | √ |
| 创建或修改计费模式 | √ | x | x | x | x | x | √ | x | √ |
| 查询域名统计数据 | √ | √ | √ | x | x | x | √ | x | x |
| 日志查询 | √ | √ | x | √ | x | x | √ | x | x |
| 查询域名所有配置 | √ | √ | x | x | √ | x | √ | √ | √ |
| 修改域名所有配置 | √ | x | x | x | √ | x | √ | x | x |
| 创建加速域名 | √ | x | x | x | √ | x | √ | x | x |
| 查询账户信息 | √ | √ | x | x | √ | x | √ | √ | x |
| 修改账户信息 | √ | x | x | x | √ | x | √ | √ | x |
不能单独配置CDN DomainConfigurationPolicy和CDN RefreshAndPreheatPolicy权限,如果想配置这两个权限,请同时配置CDN DomainReadOnlyPolicy权限,否则会造成所有域名不可见导致无法进行域名配置和刷新预热配置。
CDN控制台功能依赖的身份策略
CDN对其他云服务有诸多依赖关系,因此在您开启IAM系统身份策略授权后,在CDN Console控制台的各项功能需要配置相应的服务权限后才能正常查看或使用,前提条件如下:
- 依赖服务的权限配置均基于您已设置了IAM系统策略授权的CDN FullAccess策略权限。
如果IAM用户需要在CDN Console控制台拥有相应功能的查看或使用权限,请确认已经对该用户所在的用户组设置了CDN Administrator、CDN FullAccess策略的集群权限,再按如下表7增加依赖服务的权限。
| Console控制台功能 | 依赖服务 | 需配置角色/策略 |
|---|---|---|
| OBS委托授权 | 统一身份认证服务 IAM |
|
| 源站配置
| 对象存储服务 OBS |
|