权限管理
如果您需要对AOM资源给企业中的员工设置不同的访问权限,以达到不同员工之间的权限隔离,您可以使用统一身份认证服务(Identity and Access Management,简称IAM)进行精细的权限管理。该服务提供用户身份认证、权限分配、访问控制等功能,可以帮助您安全地控制AOM资源的访问。
通过IAM,您可以在账号中给员工创建IAM用户,并使用策略来控制其对AOM资源的访问范围。例如您的员工中有负责软件开发的人员,您希望人员拥有AOM的使用权限,但是不希望其拥有删除应用发现规则等高危操作的权限,那么您可以使用IAM为开发人员创建用户,通过授予仅能使用应用发现规则,但是不允许删除应用发现规则的权限策略,控制其对应用发现规则资源的使用范围。
如果账号已经能满足您的使用需求,不需要创建独立的IAM用户进行权限管理,您可以跳过本章节,不影响您使用AOM的其它功能。
IAM是提供权限管理的基础服务,无需付费即可使用,您只需要为您账号中的资源进行付费。关于IAM的详细介绍,请参见《IAM产品介绍》。
AOM权限
默认情况下,管理员创建的IAM用户没有任何权限,您需要将其加入用户组,并给用户组授予策略或角色,才能使得用户组中的用户获得对应的权限,这一过程称为授权。授权后,用户就可以基于被授予的权限对AOM进行操作。
AOM部署时通过物理区域划分,为项目级服务。授权时,“作用范围”需要选择“区域级项目”,然后在指定区域对应的项目中设置相关权限,并且该权限仅对此项目生效;如果在“所有项目”中设置权限,则该权限在所有区域项目中都生效。访问AOM时,需要先切换至授权区域。
根据授权精细程度分为角色和策略。
- 角色:IAM最初提供的一种根据用户的工作职能定义权限的粗粒度授权机制。该机制以服务为粒度,提供有限的服务相关角色用于授权。由于云服务平台各服务之间存在业务依赖关系,因此给用户授予角色时,可能需要一并授予依赖的其他角色,才能正确完成业务。角色并不能满足用户对精细化授权的要求,无法完全达到企业对权限最小化的安全管控要求。
- 策略:IAM最新提供的一种细粒度授权的能力,可以精确到具体服务的操作、资源以及请求条件等。基于策略的授权是一种更加灵活的授权方式,能够满足企业对权限最小化的安全管控要求。例如:针对ECS服务,管理员能够控制IAM用户仅能对某一类云服务器资源进行指定的管理操作。多数细粒度策略以API接口为粒度进行权限拆分。
| 子服务名称 | 策略名称 | 描述 | 类别 | 依赖系统权限 |
|---|---|---|---|---|
| 监控中心/采集管理 | AOM Admin | AOM2.0管理员权限,拥有该权限的用户可以操作并使用AOM。 | 系统策略 | CCE FullAccess、DMS ViewerAccess、CCE命名空间权限、LTS FullAccess 其中CCE命名空间权限需授予用户或用户组全部命名空间的管理员权限(cluster-admin)或自定义权限。如果是自定义权限,需至少包含get、list、update操作权限,并指定configmaps、prometheuses、servicemonitors、podmonitors、namespaces资源。 |
| AOM Viewer | AOM2.0只读权限,拥有该权限的用户仅能查看AOM数据。 | 系统策略 | CCE ReadOnlyAccess、DMS ViewerAccess、CCE命名空间权限、LTS ReadOnlyAccess 其中CCE命名空间权限需授予用户或用户组全部命名空间的管理员权限(cluster-admin)或自定义权限。如果是自定义权限,需至少包含get、list操作权限,并指定configmaps、prometheuses、servicemonitors、podmonitors、namespaces资源。 |
资源监控常用操作与系统权限
表2列出了资源监控常用操作与系统权限的授权关系,您可以参照该表选择合适的系统权限。
| 操作 | AOM Admin | AOM Viewer |
|---|---|---|
| 创建告警规则 | √ | x |
| 修改告警规则 | √ | x |
| 删除告警规则 | √ | x |
| 创建告警模板 | √ | x |
| 修改告警模板 | √ | x |
| 删除告警模板 | √ | x |
| 创建告警通知规则 | √ | x |
| 修改告警通知规则 | √ | x |
| 删除告警通知规则 | √ | x |
| 创建消息模板 | √ | x |
| 修改消息模板 | √ | x |
| 删除消息模板 | √ | x |
| 创建分组规则 | √ | x |
| 修改分组规则 | √ | x |
| 删除分组规则 | √ | x |
| 创建抑制规则 | √ | x |
| 修改抑制规则 | √ | x |
| 删除抑制规则 | √ | x |
| 创建静默规则 | √ | x |
| 修改静默规则 | √ | x |
| 删除静默规则 | √ | x |
| 创建仪表盘 | √ | x |
| 修改仪表盘 | √ | x |
| 删除仪表盘 | √ | x |
| 创建Prometheus实例 | √ | x |
| 修改Prometheus实例 | √ | x |
| 删除Prometheus实例 | √ | x |
| 创建应用发现规则 | √ | x |
| 修改应用发现规则 | √ | x |
| 删除应用发现规则 | √ | x |
| 订阅阈值告警 | √ | x |
| 配置虚机日志采集路径 | √ | x |
采集管理常用操作与系统权限
表3列出了采集管理常用操作与系统权限的授权关系,您可以参照该表选择合适的系统权限。
| 操作 | AOM Admin | AOM Viewer |
|---|---|---|
| 查询代理区域 | √ | √ |
| 编辑代理区域 | √ | x |
| 删除代理区域 | √ | x |
| 新建代理区域 | √ | x |
| 查询某代理区域内所有的代理机 | √ | √ |
| 查询全部代理区域 | √ | √ |
| 安装Agent结果详情 | √ | √ |
| 获取对应主机的安装命令 | √ | √ |
| 获取对应主机的心跳及和server的连接状况 | √ | √ |
| 批量卸载运行中的Agent | √ | x |
| 查询Agent首页 | √ | √ |
| 测试安装机和目标机的连通性 | √ | x |
| 批量导入安装Agent | √ | x |
| 获取Agent最近一次操作的执行日志相关信息 | √ | √ |
| 获取Agent安装时可选择的版本列表 | √ | √ |
| 获取当前项目ID下所有Agent版本号列表 | √ | √ |
| 删除多条Agent主机 | √ | x |
| 根据ecs_id查询Agent信息 | √ | √ |
| 删除单条Agent主机 | √ | x |
| 设置安装机 | √ | x |
| 重置安装机参数 | √ | x |
| 查询当前登录用户的项目能够被设置成安装机的列表 | √ | √ |
| 查询Agent安装机列表 | √ | √ |
| 删除安装机 | √ | x |
| 批量升级Agent | √ | x |
| 查询历史任务详情日志 | √ | √ |
| 查询历史任务详情 | √ | √ |
| 查询全部历史任务 | √ | √ |
| 获取所有种类的执行状态和任务类型 | √ | √ |
| 获取历史任务详情里Agent的执行状态种类 | √ | √ |
| 编辑代理机 | √ | x |
| 删除Agent代理主机 | √ | x |
| 设置代理主机 | √ | x |
| 查询当前用户能够被设置成代理机的列表 | √ | √ |
| 批量更新插件 | √ | x |
| 批量卸载插件 | √ | x |
| 批量安装插件 | √ | x |
| 查询插件历史任务详情日志 | √ | √ |
| 查询插件执行历史记录的分页列表 | √ | √ |
| 根据任务id,查询插件执行记录详情的分页列表 | √ | √ |
| 获取历史任务详情里插件的执行状态的种类 | √ | √ |
| 获取全部插件列表 | √ | √ |
| 查询插件对应的版本号 | √ | √ |
| 查询当前支持的插件列表 | √ | √ |
| 获取租户下CCE集群信息列表 | √ | √ |
| 获取租户下某个CCE集群下的Agent信息列表 | √ | √ |
| 给租户下某个CCE集群安装ICAgent | √ | x |
| 给租户下某个CCE集群升级ICAgent | √ | x |
| 给租户下某个CCE集群卸载ICAgent | √ | x |
| 获取CCE集群列表 | √ | √ |
| 获取ICAgent机器列表 | √ | √ |
| CCE集群机器安装ICAgent | √ | x |
| CCE集群机器升级ICAgent | √ | x |
| CCE集群机器卸载ICAgent | √ | x |
细粒度权限说明
使用自定义细粒度策略,请使用管理员用户进入统一身份认证(IAM)服务,按需选择AOM的细粒度权限进行授权操作。AOM细粒度权限说明请参见表4。
| 权限名称 | 权限描述 | 权限依赖 | 应用场景 |
|---|---|---|---|
| aom:alarm:put | 上报告警 | 无 | 上报自定义告警 |
| aom:event2AlarmRule:create | 新增一条事件类告警规则 | 新增一条事件类告警规则 | |
| aom:event2AlarmRule:set | 更新事件类告警规则 | 更新事件类告警规则 | |
| aom:event2AlarmRule:delete | 删除事件类告警规则 | 删除事件类告警规则 | |
| aom:event2AlarmRule:list | 查询全部事件类告警规则 | 查询全部事件类告警规则 | |
| aom:actionRule:create | 新增告警通知规则 | 新增告警通知规则 | |
| aom:actionRule:delete | 删除告警通知规则 | 删除告警通知规则 | |
| aom:actionRule:list | 获取告警通知规则列表 | 获取告警通知规则列表 | |
| aom:actionRule:update | 修改告警通知规则 | 修改告警通知规则 | |
| aom:actionRule:get | 通过规则名称获取告警通知规则 | 通过规则名称获取告警通知规则 | |
| aom:alarm:list | 获取告警发送结果 | 获取告警发送结果 | |
| aom:alarmRule:create | 创建阈值规则 | 创建阈值规则 | |
| aom:alarmRule:set | 修改阈值规则 | 修改阈值规则 | |
| aom:alarmRule:get | 查询阈值规则 | 根据ID查询单个阈值规则或者查询所有阈值规则 | |
| aom:alarmRule:delete | 删除阈值规则 | 批量删除阈值规则或者根据ID删除单个阈值规则 | |
| aom:discoveryRule:list | 查看应用发现规则 | 查询系统中已有应用发现规则 | |
| aom:discoveryRule:delete | 删除应用发现规则 | 删除应用发现规则 | |
| aom:discoveryRule:set | 添加应用发现规则 | 添加应用发现规则 | |
| aom:metric:list | 查询时间序列 | 查询时间序列 | |
| aom:metric:list | 查询时序数据 | 查询时序数据 | |
| aom:metric:get | 查询指标 | 查询指标 | |
| aom:metric:get | 查询监控数据 | 查询监控数据 | |
| aom:muteRule:delete | 删除静默规则 | 无 | 删除静默规则 |
| aom:muteRule:create | 新增静默规则 | 新增静默规则 | |
| aom:muteRule:update | 修改静默规则 | 修改静默规则 | |
| aom:muteRule:list | 获取静默规则列表 | 获取静默规则列表 |
AOM控制台功能依赖的角色或策略
如果IAM用户需要在AOM控制台拥有相应功能的查看或使用权限,请确认已经对该用户所在的用户组设置了AOM Admin或AOM Viewer策略的集群权限,再按如下表5增加依赖服务的角色或策略。用户首次开通AOM服务,AOM会为其创建服务委托,用户除需授权AOM Admin外,还需要授予Security Administrator。
| 控制台功能 | 依赖服务 | 需配置角色/策略 |
|---|---|---|
| 云容器引擎 CCE | 如果使用Prometheus for CCE、工作负载监控和集群监控,需要设置CCE FullAccess权限和CCE命名空间权限。 |
| 数据订阅 | 分布式消息服务Kafka版 | 如果使用数据订阅功能,需要设置DMS ViewerAccess权限。 |
| 云日志服务LTS | 如果使用日志管理、日志转储、日志接入规则、主机组管理、日志告警规则功能,需要设置LTS FullAccess权限。 |
| 企业项目 | 企业项目管理 EPS | 如果使用企业项目功能需要设置EPS ReadOnlyAccess权限。 |