RAM authorization

更新时间:
复制 MD 格式

Resource Access Management (RAM) is a service provided by Alibaba Cloud to manage user identities and resource access permissions. Using RAM helps you avoid sharing your Alibaba Cloud account keys with other users and allows you to grant users the least privilege access. RAM uses permission policies to define authorizations. This topic describes the general structure of a RAM policy, and the policy statement elements (Action, Resource, and Condition) defined by E-MapReduce for RAM permission policies. The RAM code (RamCode) for E-MapReduce is starrocks,sr , and the supported authorization granularity is OPERATION .

General structure of a policy

Permission policies support JSON format with the following general structure:

{
  "Version": "1",
  "Statement": [
    {
      "Effect": "<Effect>",
      "Action": "<Action>",
      "Resource": "<Resource>",
      "Condition": {
        "<Condition_operator>": {
          "<Condition_key>": [
            "<Condition_value>"
          ]
        }
      }
    }
  ]
}        

The following list describes the fields in the policy:

  • Version: Specifies the policy version number. It is fixed at 1.

  • Statement:

    • Effect: Specifies the authorization result. Valid values: Allow and Deny.

    • Action: Specifies one or more operations that are allowed or denied.

    • Resource: Specifies the specific objects affected by the operations. You can use Alibaba Cloud Resource Names (ARNs) to describe specific resources.

    • Condition: Specifies the conditions for the authorization to take effect. This field is optional.

      • Condition operator: Specifies the conditional operators. Different types of conditions support different conditional operators.

      • Condition_key: Specifies the condition keys.

      • Condition_value: Specifies the condition values.

Action

The following table lists the actions defined by E-MapReduce. The table's columns are detailed below:

  • Action: The actions can be used in the Action element of RAM permission policy statements to grant permissions to perform the operation.

  • API: The API that you can call to perform the action.

  • Access level: The predefined level of access granted for each API. Valid values: create, list, get, update, and delete.

  • Resource type: The type of the resource that support authorization to perform the action. It indicates if the action supports resource-level permission. The specified resource must be compatible with the action. Otherwise, the policy will be ineffective.

    • For APIs with resource-level permissions, required resource types are marked with an asterisk (*). Specify the corresponding ARN in the Resource element of the policy.

    • For APIs without resource-level permissions, it is shown as All Resources. Use an asterisk (*) in the Resource element of the policy.

  • Condition key: The condition keys defined by the service. The key allows for granular control, applying to either actions alone or actions associated with specific resources. In addition to service-specific condition keys, Alibaba Cloud provides a set of common condition keys that are applicable across all RAM-integrated services. For more information, see Common condition keys.

  • Dependent action: The dependent actions required to run the action. To complete the action, the RAM user or the RAM role must have the permissions to perform all dependent actions.

Action

API

Access level

Resource type

Condition key

Dependent action

sr:GetInstanceFeatureGate GetInstanceFeatureGate update

*Instance

acs:sr:{#regionId}:{#accountId}:instance/{#InstanceId}

None None
sr:UpdateBackupPolicy UpdateBackupPolicy none

*All Resource

*

None None
sr:DescribeInstanceConfigs DescribeInstanceConfigs get

*Instance

acs:sr:{#regionId}:{#accountId}:instance/{#InstanceId}

None None
sr:QueryModifyDiskTypePrice QueryModifyDiskTypePrice get

*Instance

acs:sr:{#regionId}:{#accountId}:instance/{#InstanceId}

None None
sr:UpgradeVersion UpgradeVersion update

*Instance

acs:sr:{#regionId}:{#accountId}:instance/{#InstanceId}

None None
sr:DisableSSLConnection DisableSSLConnection update

*Instance

acs:sr:{#regionId}:{#accountId}:instance/{#InstanceId}

None None
sr:ResumeInstance ResumeInstance update

*Instance

acs:sr:{#regionId}:{#accountId}:instance/{#InstanceId}

None None
sr:RollbackConfigModification RollbackConfigModification none

*Instance

acs:sr:{#regionId}:{#accountId}:instance/{#InstanceId}

None None
sr:ModifySpecTypePreCheck ModifySpecTypePreCheck get

*Instance

acs:sr:{#regionId}:{#accountId}:instance/{#InstanceId}

None None
sr:UpdateBackup UpdateBackup none

*All Resource

*

None None
sr:AddGateway AddGateway create

*Instance

acs:sr:{#regionId}:{#accountId}:instance/{#InstanceId}

None None
sr:DeleteBackupPolicy DeleteBackupPolicy none

*All Resource

*

None None
sr:QueryModifySpecTypePrice QueryModifySpecTypePrice get

*Instance

acs:sr:{#regionId}:{#accountId}:instance/{#InstanceId}

None None
sr:EnableMultiAz EnableMultiAz update

*All Resource

*

None None
sr:QueryModifyDiskPerformanceLevelPrice QueryModifyDiskPerformanceLevelPrice get

*Instance

acs:sr:{#regionId}:{#accountId}:instance/{#InstanceId}

None None
sr:GetNodeGroupFeatureGate GetNodeGroupFeatureGate update

*Instance

acs:sr:{#regionId}:{#accountId}:instance/{#InstanceId}

None None
sr:UpdateNodeGroupDescription UpdateNodeGroupDescription update

*All Resource

*

None None
sr:ModifyDiskType ModifyDiskType update

*Instance

acs:sr:{#regionId}:{#accountId}:instance/{#InstanceId}

None None
sr:DeleteGateway DeleteGateway delete

*Instance

acs:sr:{#regionId}:{#accountId}:instance/{#InstanceId}

None None
sr:DescribeSystemTimezone DescribeSystemTimezone update

*Instance

acs:sr:{#regionId}:{#accountId}:instance/{#InstanceId}

None None
sr:ModifyMaintainableTime ModifyMaintainableTime update

*All Resource

*

None None
sr:CreateServiceLinkedRole CreateServiceLinkedRole none

*All Resource

*

None None
sr:DescribeBackupPolicies DescribeBackupPolicies none

*Instance

acs:sr:{#regionId}:{#accountId}:instance/{#InstanceId}

None None
sr:RenewInstance RenewInstance update

*Instance

acs:sr:{#regionId}:{#accountId}:instance/{#InstanceId}

None None
sr:UpdateInnerIpWhitelistGroup UpdateInnerIpWhitelistGroup none

*All Resource

*

None None
sr:DeleteInnerIpWhitelistGroup DeleteInnerIpWhitelistGroup none

*All Resource

*

None None
sr:TogglePublicSlb TogglePublicSlb create

*Instance

acs:sr:{#regionId}:{#accountId}:instance/{#InstanceId}

None None
sr:RestartInstance RestartInstance none

*Instance

acs:sr:{#regionId}:{#accountId}:instance/{#InstanceId}

None None
sr:QueryEnableMultiAzPrice QueryEnableMultiAzPrice get

*All Resource

*

None None
sr:ModifyInstanceConfig ModifyInstanceConfig update

*Instance

acs:sr:{#regionId}:{#accountId}:instance/{#InstanceId}

None None
sr:EnableInternalSlb EnableInternalSlb get

*Instance

acs:sr:{#regionId}:{#accountId}:instance/{#InstanceId}

None None
sr:ModifyInstanceConfigPreCheck ModifyInstanceConfigPreCheck update

*Instance

acs:sr:{#regionId}:{#accountId}:instance/{#InstanceId}

None None
sr:QueryMinorVersion QueryMinorVersion get

*All Resource

*

None None
sr:DeleteScalingRule DeleteScalingRule none

*All Resource

*

None None
sr:ModifySpecType ModifySpecType get

*Instance

acs:sr:{#regionId}:{#accountId}:instance/{#InstanceId}

None None
sr:ModifyChargeType ModifyChargeType update

*All Resource

*

None None
sr:QueryUpgradableVersions QueryUpgradableVersions get

*Instance

acs:sr:{#regionId}:{#accountId}:instance/{#InstanceId}

None None
sr:QueryModifyNodeNumberPrice QueryModifyNodeNumberPrice get

*Instance

acs:sr:{#regionId}:{#accountId}:instance/{#InstanceId}

None None
sr:QueryPriceV1 QueryPriceV1 none

*All Resource

*

None None
sr:ModifyScalingRule ModifyScalingRule update

*All Resource

*

None None
sr:ModifyCu ModifyCu get

*Instance

acs:sr:{#regionId}:{#accountId}:instance/{#InstanceId}

None None
sr:ModifyNodeNumberPreCheck ModifyNodeNumberPreCheck get

*Instance

acs:sr:{#regionId}:{#accountId}:instance/{#InstanceId}

None None
sr:QueryRefundPrice QueryRefundPrice none

*All Resource

*

None None
sr:ListOperationActivity ListOperationActivity get

*Instance

acs:sr:{#regionId}:{#accountId}:instance/{#InstanceId}

None None
sr:CreateScalingRule CreateScalingRule none

*All Resource

*

None None
sr:RebootECS RebootECS get

*Instance

acs:sr:{#regionId}:{#accountId}:instance/{#InstanceId}

None None
sr:EnableSSLConnection EnableSSLConnection update

*All Resource

*

None None
sr:ModifyDiskSize ModifyDiskSize get

*Instance

acs:sr:{#regionId}:{#accountId}:instance/{#InstanceId}

None None
sr:UpdateInstanceName UpdateInstanceName update

*Instance

acs:sr:{#regionId}:{#accountId}:instance/{#InstanceId}

None None
sr:ModifyCuPreCheck ModifyCuPreCheck get

*Instance

acs:sr:{#regionId}:{#accountId}:instance/{#InstanceId}

None None
sr:RestartNodeGroup RestartNodeGroup none

*Instance

acs:sr:{#regionId}:{#accountId}:instance/{#InstanceId}

None None
sr:ChangeResourceGroup ChangeResourceGroup create

*Instance

acs:sr:{#regionId}:{#accountId}:instance/{#InstanceId}

None None
sr:DescribeEventNames DescribeEventNames get

*All Resource

*

None None
sr:ListOperationHistory ListOperationHistory get

*Instance

acs:sr:{#regionId}:{#accountId}:instance/{#InstanceId}

None None
sr:QueryRenewPrice QueryRenewPrice get

*Instance

acs:sr:{#regionId}:{#accountId}:instance/{#InstanceId}

None None
sr:TagResources TagResources create

*All Resource

*

None None
sr:ListGateway ListGateway get

*Instance

acs:sr:{#regionId}:{#accountId}:instance/{#InstanceId}

None None
sr:DeleteBackup DeleteBackup none

*Instance

acs:sr:{#regionId}:{#accountId}:instance/{#InstanceId}

None None
sr:AddBackupPolicy AddBackupPolicy none

*All Resource

*

None None
sr:DescribeInstanceMetaToken DescribeInstanceMetaToken update

*Instance

acs:sr:{#regionId}:{#accountId}:instance/{#InstanceId}

None None
sr:ReleaseInstance ReleaseInstance delete

*Instance

acs:sr:{#regionId}:{#accountId}:instance/{#InstanceId}

None None
sr:QueryModifyCuPrice QueryModifyCuPrice get

*Instance

acs:sr:{#regionId}:{#accountId}:instance/{#InstanceId}

None None
sr:DescribeConfigHistory DescribeConfigHistory get

*Instance

acs:sr:{#regionId}:{#accountId}:instance/{#InstanceId}

None None
sr:DescribeTimeTriggerScalingRules DescribeTimeTriggerScalingRules get

*All Resource

*

None None
sr:ListSSLDetails ListSSLDetails get

*Instance

acs:sr:{#regionId}:{#accountId}:instance/{#InstanceId}

None None
sr:QueryModifyDiskSizePrice QueryModifyDiskSizePrice get

*Instance

acs:sr:{#regionId}:{#accountId}:instance/{#InstanceId}

None None
sr:RestoreInstance RestoreInstance create

*All Resource

*

None None
sr:DescribeInstances DescribeInstances get

*Instance

acs:sr:{#regionId}:{#accountId}:instance/{#InstanceId}

None None
sr:ModifyHostAlias ModifyHostAlias none

*All Resource

*

None None
sr:DescribeBackups DescribeBackups none

*All Resource

*

None None
sr:QueryModifyChargeTypePrice QueryModifyChargeTypePrice none

*All Resource

*

None None
sr:CheckInventory CheckInventory get

*All Resource

*

None None
sr:DescribeNodeGroups DescribeNodeGroups get

*All Resource

*

None None
sr:UnTagResources UnTagResources create

*All Resource

*

None None
sr:DescribeInstanceDiagnosisResult DescribeInstanceDiagnosisResult get

*All Resource

*

None None
sr:UpdatePublicNetworkStatus UpdatePublicNetworkStatus update

*Instance

acs:sr:{#regionId}:{#accountId}:instance/{#InstanceId}

None None
sr:ModifyUserPassword ModifyUserPassword get

*Instance

acs:sr:{#regionId}:{#accountId}:instance/{#InstanceId}

None None
sr:CreateInstanceV1 CreateInstanceV1 create

*All Resource

*

None None
sr:CreateAgentResource CreateAgentResource get

*All Resource

*

None None
sr:ModifyDiskPerformanceLevel ModifyDiskPerformanceLevel update

*Instance

acs:sr:{#regionId}:{#accountId}:instance/{#InstanceId}

None None
sr:IsolateLeader IsolateLeader get

*Instance

acs:sr:{#regionId}:{#accountId}:instance/{#InstanceId}

None None
sr:ToggleAutoMinorVersionUpgrade ToggleAutoMinorVersionUpgrade update

*Instance

acs:sr:{#regionId}:{#accountId}:instance/{#InstanceId}

None None
sr:QueryModifyDiskNumberPrice QueryModifyDiskNumberPrice get

*Instance

acs:sr:{#regionId}:{#accountId}:instance/{#InstanceId}

None None
sr:SwitchActiveStandbyZones SwitchActiveStandbyZones get

*Instance

acs:sr:{#regionId}:{#accountId}:instance/{#InstanceId}

None None
sr:ModifyDiskNumber ModifyDiskNumber get

*Instance

acs:sr:{#regionId}:{#accountId}:instance/{#InstanceId}

None None
sr:UpdateGateway UpdateGateway get

*Instance

acs:sr:{#regionId}:{#accountId}:instance/{#InstanceId}

None None
sr:RestartNodes RestartNodes none

*Instance

acs:sr:{#regionId}:{#accountId}:instance/{#InstanceId}

None None
sr:ModifyNodeNumber ModifyNodeNumber get

*Instance

acs:sr:{#regionId}:{#accountId}:instance/{#InstanceId}

None None
sr:DescribeInnerIpWhitelistGroups DescribeInnerIpWhitelistGroups none

*All Resource

*

None None
sr:QueryUnpaidOrder QueryUnpaidOrder get

*Instance

acs:sr:{#regionId}:{#accountId}:instance/{#InstanceId}

None None

Resource

The following table lists the resources defined by E-MapReduce. Specify them in the Resource element of RAM policy statements to grant permissions for specific operations. They are uniquely identified by ARNs. Format: acs:{#ramcode}:{#regionId}:{#accountId}:{#resourceType}:

  • acs: The initialism of Alibaba Cloud service, which indicates the public cloud of Alibaba Cloud.

  • {#ramcode}: The code used in RAM to indicate an Alibaba Cloud service.

  • {#regionId}: The region ID. If the resource covers all regions, set it to an asterisk (*).

  • {#accountId}: The ID of the Alibaba Cloud account. If the resource covers all Alibaba Cloud accounts, set it to an asterisk (*).

  • {#resourceType}: The service-defined resource identifier. It supports a hierarchical structure, which is similar to a file path. If the statement covers global resources, set it to an asterisk (*).

Resource type

ARN

Instance
  • acs:sr:{#regionId}:{#accountId}:instance/{#InstanceId}
  • acs:sr:{#regionId}:{#accountId}:*

Condition

E-MapReduce does not define product-level condition keys. However, you can use Alibaba Cloud common condition keys for access control. For more information, see Common condition keys.

How to create custom RAM policies?

You can create custom policies and grant them to RAM users, RAM user groups, or RAM roles. For instructions, see: