Resource Access Management (RAM) は Alibaba Cloud によって提供される、ユーザーのアイデンティティとリソースの権限を管理するためのサービスです。RAM を使用すると、Alibaba Cloud アカウント (root ユーザー) のキーを他のユーザーと共有することを回避でき、ユーザーに必要最小限の権限を付与できます。RAM ではポリシーを使用して権限付与を定義します。このトピックでは、RAM ポリシーの一般的な構造と、 のポリシーステートメントを構成する要素である「アクション (Action)」「リソース (Resource)」および「条件 (Condition) 」について説明します。 は、RAM コード (RamCode) が clickhouse で、 RESOURCE での権限付与がサポートされています。
一般的なポリシー構造
RAM ポリシーは、一般的に以下のような JSON 構造で構成されます。
{
"Version": "1",
"Statement": [
{
"Effect": "<Effect>",
"Action": "<Action>",
"Resource": "<Resource>",
"Condition": {
"<Condition_operator>": {
"<Condition_key>": [
"<Condition_value>"
]
}
}
}
]
} ポリシーのフィールドに関する説明:
Version:ポリシーのバージョン番号。現在のポリシーバージョンは 1 です。
Statement:
Effect:「許可するか、拒否するか」という、最終的な結果を定義します。有効な値:Allow (許可) または Deny (拒否)。
Action:「何をすることができるか、できないか」を定義する、リソースへの具体的な操作を指します。
Resource:「何に対して操作を行うか」を定義する、操作の具体的な対象です。対象となるリソースは、ARN (Alibaba Cloud Resource Name) を使用して指定できます。
Condition:「どのような状況下でポリシーが適用されるか」という、権限が有効になるための付加的な制約条件を定義します。このフィールドは任意です。
Condition operator:条件の演算子。条件キーの値とリクエスト値をどのように比較するかを定義する「比較方法」です。条件演算子は、条件のタイプによって異なります。
Condition_key:条件のキー。ポリシーの条件が満たされているかを判断するために、リクエストから参照・チェックされる特定の属性を指します。
Condition_value:条件の値。条件キーから取得されたリクエスト値と比較するための、具体的な「基準値」です。
アクション (Action)
下表に、 で定義されたアクションを示します。以下で各列名について説明します。
アクション:特定のリソースに対して実行可能な操作。ポリシー構文では
Action要素として指定します。API:アクションを具体的に実行するための API。
アクセスレベル:各 API に対して事前定義されているアクセスの種類。有効な値:create、list、get、update、delete。
リソースタイプ:アクションが作用するリソースの種類。リソースレベルでの権限をサポートするかどうかを示すことができます。ポリシーの有効性を確保するため、アクションの対象として適切なリソースを指定する必要があります。
リソースレベルの権限を持つ API の場合、必要なリソースタイプはアスタリスク (*) でマークされます。ポリシーの
Resource要素で対応する ARN を指定してください。リソースレベルの権限を持たない API の場合、「すべてのリソース」と表示され、ポリシーの
Resource要素でアスタリスク (*) でマークされます。
条件キー:サービスによって定義された条件のキー。このキーにより、きめ細やかなアクセス制御が可能になります。この制御は、アクション単体に適用することも、特定のリソースに対するアクションに適用することもできます。Alibaba Cloud は、サービス固有の条件キーに加えて、すべての RAM 統合サービスに適用可能な一連の共通条件キーを提供しています。詳細については、「共通条件キー」をご参照ください。
依存アクション:ある特定のアクションを実行するために、前提として実行が必要となる他のアクション。依存アクションの権限も RAM ユーザーまたは RAM ロールに付与する必要があります。
|
アクション |
API |
アクセスレベル |
リソースタイプ |
条件キー |
依存アクション |
| clickhouse:ModifyActiveOperationMaintainConf | ModifyActiveOperationMaintainConf | none |
*All Resource
|
なし | なし |
| clickhouse:DescribeAutoRenewAttribute | DescribeAutoRenewAttribute | get |
*DBCluster
|
なし | なし |
| clickhouse:ChangeResourceGroup | ChangeResourceGroup | update |
*DBCluster
|
なし | なし |
| clickhouse:DescribeColumns | DescribeColumns | get |
*All Resource
|
なし | なし |
| clickhouse:DescribeSynDbTables | DescribeSynDbTables | get |
*DBCluster
|
なし | なし |
| clickhouse:RestartInstance | RestartInstance | update |
*DBCluster
|
なし | なし |
| clickhouse:DeleteDBCluster | DeleteDBCluster | delete |
*All Resource
|
なし | なし |
| clickhouse:ModifyBackupPolicy | ModifyBackupPolicy | update |
*All Resource
|
なし | なし |
| clickhouse:DeleteSyndb | DeleteSyndb | delete |
*DBCluster
|
なし | なし |
| clickhouse:DeleteSLB | DeleteSLB | delete |
*All Resource
|
なし | なし |
| clickhouse:CheckScaleOutBalanced | CheckScaleOutBalanced | get |
*DBCluster
|
なし | なし |
| clickhouse:DeleteBackupPolicy | DeleteBackupPolicy | delete |
*All Resource
|
なし | なし |
| clickhouse:DescribeSynDbs | DescribeSynDbs | get |
*DBCluster
|
なし | なし |
| clickhouse:ModifyMinorVersionGreadeType | ModifyMinorVersionGreadeType | update |
*DBCluster
|
なし | なし |
| clickhouse:ResetAccountPassword | ResetAccountPassword | update |
*All Resource
|
なし | なし |
| clickhouse:ModifyDBClusterAccessWhiteList | ModifyDBClusterAccessWhiteList | update |
*All Resource
|
なし | なし |
| clickhouse:DescribeAccounts | DescribeAccounts | get |
*All Resource
|
なし | なし |
| clickhouse:ModifyDBConfig | ModifyDBConfig | update |
*DBCluster
|
なし | なし |
| clickhouse:DescribeUserEncryptionKeyList | DescribeUserEncryptionKeyList | get |
*All Resource
|
なし | なし |
| clickhouse:CancelActiveOperationTasks | CancelActiveOperationTasks | none |
*All Resource
|
なし | なし |
| clickhouse:DescribeSlowLogRecords | DescribeSlowLogRecords | get |
*DBCluster
|
なし | なし |
| clickhouse:DescribeTransferHistory | DescribeTransferHistory | get |
*DBCluster
|
なし | なし |
| clickhouse:CreateAccount | CreateAccount | create |
*All Resource
|
なし | なし |
| clickhouse:DescribeAllDataSource | DescribeAllDataSource | get |
*All Resource
|
なし | なし |
| clickhouse:DescribeAccountAuthority | DescribeAccountAuthority | get |
*DBCluster
|
なし | なし |
| clickhouse:DescribeActiveOperationMaintainConf | DescribeActiveOperationMaintainConf | get |
*All Resource
|
なし | なし |
| clickhouse:CreateServiceLinkedRole | CreateServiceLinkedRole | create |
*All Resource
|
なし | なし |
| clickhouse:ModifyDBClusterDescription | ModifyDBClusterDescription | update |
*All Resource
|
なし | なし |
| clickhouse:ReleaseClusterPublicConnection | ReleaseClusterPublicConnection | update |
*All Resource
|
なし | なし |
| clickhouse:CreatePortsForClickHouse | CreatePortsForClickHouse | create |
*All Resource
|
なし | なし |
| clickhouse:CheckServiceLinkedRole | CheckServiceLinkedRole | get |
*All Resource
|
なし | なし |
| clickhouse:CheckClickhouseToRDS | CheckClickhouseToRDS | get |
*DBCluster
|
なし | なし |
| clickhouse:CreateSLB | CreateSLB | create |
*All Resource
|
なし | なし |
| clickhouse:DescribeDBClusterConfigInXML | DescribeDBClusterConfigInXML | get |
*All Resource
|
なし | なし |
| clickhouse:CreateOSSStorage | CreateOSSStorage | create |
*DBCluster
|
なし | なし |
| clickhouse:DescribeDBClusterPerformance | DescribeDBClusterPerformance | get |
*All Resource
|
なし | なし |
| clickhouse:CreateSQLAccount | CreateSQLAccount | create |
*DBCluster
|
なし | なし |
| clickhouse:KillProcess | KillProcess | update |
*DBCluster
|
なし | なし |
| clickhouse:DescribeSchemas | DescribeSchemas | get |
*All Resource
|
なし | なし |
| clickhouse:DescribeBackups | DescribeBackups | get |
*DBCluster
|
なし | なし |
| clickhouse:ModifyRDSToClickhouseDb | ModifyRDSToClickhouseDb | update |
*DBCluster
|
なし | なし |
| clickhouse:DescribeProcessList | DescribeProcessList | get |
*DBCluster
|
なし | なし |
| clickhouse:ModifyDBClusterMaintainTime | ModifyDBClusterMaintainTime | update |
*All Resource
|
なし | なし |
| clickhouse:ModifyDBCluster | ModifyDBCluster | update |
*DBCluster
|
なし | なし |
| clickhouse:DescribeOSSStorage | DescribeOSSStorage | get |
*DBCluster
|
なし | なし |
| clickhouse:UntagResources | UntagResources | update |
*DBCluster
|
なし | なし |
| clickhouse:ModifyActiveOperationTasks | ModifyActiveOperationTasks | update |
*All Resource
|
なし | なし |
| clickhouse:CheckModifyConfigNeedRestart | CheckModifyConfigNeedRestart | get |
*All Resource
|
なし | なし |
| clickhouse:CreateAccountAndAuthority | CreateAccountAndAuthority | create |
*DBCluster
|
なし | なし |
| clickhouse:CancelRestartInstance | CancelRestartInstance | update |
*DBCluster
|
なし | なし |
| clickhouse:RestartInstanceNodeList | RestartInstanceNodeList | update |
*All Resource
|
なし | なし |
| clickhouse:CreateDBInstance | CreateDBInstance | create |
*All Resource
|
なし | なし |
| clickhouse:DeleteAccount | DeleteAccount | delete |
*All Resource
|
なし | なし |
| clickhouse:DescribeTables | DescribeTables | get |
*All Resource
|
なし | なし |
| clickhouse:DescribeDBClusterAttribute | DescribeDBClusterAttribute | get |
*All Resource
|
なし | なし |
| clickhouse:ListTagResources | ListTagResources | list |
*DBCluster
|
なし | なし |
| clickhouse:DescribeDBClusterNodeInfos | DescribeDBClusterNodeInfos | get |
*All Resource
|
なし | なし |
| clickhouse:DescribeActiveOperationTasks | DescribeActiveOperationTasks | get |
*All Resource
|
なし | なし |
| clickhouse:CheckMonitorAlert | CheckMonitorAlert | get |
*DBCluster
|
なし | なし |
| clickhouse:DescribeAllDataSources | DescribeAllDataSources | get |
*All Resource
|
なし | なし |
| clickhouse:DescribeDBClusterConfig | DescribeDBClusterConfig | get |
*DBCluster
|
なし | なし |
| clickhouse:DescribeBackupPolicy | DescribeBackupPolicy | get |
*All Resource
|
なし | なし |
| clickhouse:DescribeDBClusters | DescribeDBClusters | get |
*All Resource
|
なし | なし |
| clickhouse:ModifyAccountDescription | ModifyAccountDescription | update |
*All Resource
|
なし | なし |
| clickhouse:TagResources | TagResources | update |
*DBCluster
|
なし | なし |
| clickhouse:DescribeDBConfig | DescribeDBConfig | get |
*DBCluster
|
なし | なし |
| clickhouse:CreateRDSToClickhouseDb | CreateRDSToClickhouseDb | create |
*DBCluster
|
なし | なし |
| clickhouse:CreateBackupPolicy | CreateBackupPolicy | create |
*All Resource
|
なし | なし |
| clickhouse:AllocateClusterPublicConnection | AllocateClusterPublicConnection | update |
*All Resource
|
なし | なし |
| clickhouse:ModifyDBClusterConfig | ModifyDBClusterConfig | update |
*DBCluster
|
なし | なし |
| clickhouse:CreateMonitorDataReport | CreateMonitorDataReport | create |
*DBCluster
|
なし | なし |
| clickhouse:UpgradeMinorVersion | UpgradeMinorVersion | update |
*DBCluster
|
なし | なし |
| clickhouse:ModifyAutoRenewAttribute | ModifyAutoRenewAttribute | update |
*DBCluster
|
なし | なし |
| clickhouse:ModifyDBClusterConfigInXML | ModifyDBClusterConfigInXML | update |
*All Resource
|
なし | なし |
| clickhouse:DescribeSlowLogTrend | DescribeSlowLogTrend | get |
*DBCluster
|
なし | なし |
| clickhouse:ModifyAccountAuthority | ModifyAccountAuthority | update |
*DBCluster
|
なし | なし |
| clickhouse:DescribeConfigVersionDifference | DescribeConfigVersionDifference | get |
*All Resource
|
なし | なし |
| clickhouse:DescribeDBClusterAccessWhiteList | DescribeDBClusterAccessWhiteList | get |
*All Resource
|
なし | なし |
| clickhouse:DescribeConfigHistory | DescribeConfigHistory | get |
*All Resource
|
なし | なし |
| clickhouse:DescribeDBClusterNetInfoItems | DescribeDBClusterNetInfoItems | get |
*All Resource
|
なし | なし |
| clickhouse:TransferVersion | TransferVersion | create |
*DBCluster
|
なし | なし |
リソース (Resource)
下表に、 で定義されたリソースを示します。ポリシーステートメントのResource要素で指定することで、特定のアクションの適用対象を設定できます。各リソースは対応する ARN を持ち、一意的に識別されます。ARN はacs:{#ramcode}:{#regionId}:{#accountId}:{#resourceType}形式で、構成要素は以下のとおりです。
acs:Alibaba Cloud Service の頭文字で、Alibaba Cloud のパブリッククラウドを指します。{#ramcode}:RAM における具体的な Alibaba Cloud サービスの識別コード。{#regionId}:リージョン ID。アスタリスク (*) に設定した場合、リソースがすべてのリージョンに適用することを示します。{#accountId}:Alibaba Cloud アカウントの ID。アスタリスク (*) に設定した場合、リソースがすべての Alibaba Cloud アカウントに適用することを示します。{#resourceType}:具体的な Alibaba Cloud サービスによって定義されたリソースの識別子で、ファイルパスに似た階層構造をサポートしています。アスタリスク (*) に設定した場合、ステートメントがすべてのリソースに適用することを示します。
リソースタイプ |
ARN |
| DBCluster |
|
条件 (Condition)
下表に、 で定義されたプロダクトレベルの条件キーを示します。このほかに、Alibaba Cloud の共通条件キーを使用することもできます。これらのキーをポリシーステートメントのCondition要素として指定することで、きめ細かい権限付与ルールを定義できます。条件キーで、ポリシーのCondition_value要素で条件の値を指定します。
各条件キーには、文字列、数値、ブール値、IP アドレスといった特定のデータ型が定められています。データ型によって使用できる条件演算子が異なるため、キーのデータ型に基づいて適切な演算子を指定する必要があります。不適切な演算子を指定した場合、ポリシーステートメントは機能しません。データ型と条件演算子の対応関係については、「Condition_operator」をご参照ください。
条件キー |
説明 |
データ型 |
| clickhouse:EncryptionType | 暗号化タイプ。 |
Array |
カスタム RAM ポリシーの作成方法
カスタムポリシーを作成し、RAM ユーザー、RAM ユーザーグループ、または RAM ロールに付与できます。詳細については、以下をご参照ください。