Resource Access Management (RAM) は Alibaba Cloud によって提供される、ユーザーのアイデンティティとリソースの権限を管理するためのサービスです。RAM を使用すると、Alibaba Cloud アカウント (root ユーザー) のキーを他のユーザーと共有することを回避でき、ユーザーに必要最小限の権限を付与できます。RAM ではポリシーを使用して権限付与を定義します。このトピックでは、RAM ポリシーの一般的な構造と、 のポリシーステートメントを構成する要素である「アクション (Action)」「リソース (Resource)」および「条件 (Condition) 」について説明します。 は、RAM コード (RamCode) が mq で、 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 |
アクセスレベル |
リソースタイプ |
条件キー |
依存アクション |
| mq:QueryDLQMessage | OnsDLQMessagePageQueryByGroupId | get |
Group
Group
|
なし |
mq:OnsInstanceBaseInfo |
| mq:ListTagResources | ListTagResources | get |
*All Resource
|
なし |
mq:QueryInstanceBaseInfo |
| mq:QueryTrendGroupOutputTps | OnsTrendGroupOutputTps | get |
Group
Group
|
なし |
mq:OnsInstanceBaseInfo |
| mq:QueryDLQMessage | OnsDLQMessageGetById | get |
Group
Group
|
なし |
mq:OnsInstanceBaseInfo |
| mq:QueryConsumerStatus | OnsConsumerStatus | get |
Group
Group
|
なし |
mq:OnsInstanceBaseInfo |
| mq:QueryMessage | OnsMessagePageQueryByTopic | get |
Topic
Topic
|
なし |
mq:OnsInstanceBaseInfo |
| mq:DeleteTopic | OnsTopicDelete |
Topic
Topic
|
なし |
mq:OnsInstanceBaseInfo |
|
| mq:DeleteGroup | OnsGroupDelete | delete |
*Group
*Group
|
なし |
mq:QueryInstanceBaseInfo |
| mq:UpdateTopic | OnsTopicUpdate |
Topic
Topic
|
なし |
mq:OnsInstanceBaseInfo |
|
| mq:UpdateGroupConsumer | OnsGroupConsumerUpdate |
Group
Group
|
なし |
mq:OnsInstanceBaseInfo |
|
| mq:QueryConsumerTimeSpan | OnsConsumerTimeSpan | get |
Topic
Topic
|
なし |
mq:OnsInstanceBaseInfo |
| mq:QueryGroupSubDetail | OnsGroupSubDetail | get |
Group
Group
|
なし |
mq:OnsInstanceBaseInfo |
| mq:ResendDLQMessage | OnsDLQMessageResendById | get |
Group
|
なし |
mq:OnsInstanceBaseInfo |
| mq:UntagResources | UntagResources | get |
*All Resource
Topic
|
なし |
mq:QueryInstanceBaseInfo |
| mq:QueryConsumerConnection | OnsConsumerGetConnection | get |
Group
Group
|
なし |
mq:OnsInstanceBaseInfo |
| mq:ListGroup | OnsGroupList | list |
Group
Topic
|
なし |
mq:QueryInstanceBaseInfo |
| mq:QueryMessageDetail | OnsMessageDetail | get |
Topic
Topic
|
なし |
mq:OnsInstanceBaseInfo |
| mq:ListTopic | OnsTopicList | list |
Instance
Group
|
なし |
mq:QueryInstanceBaseInfo |
| mq:QueryTopicStatus | OnsTopicStatus | get |
Topic
Topic
|
なし |
mq:OnsInstanceBaseInfo |
| mq:QueryTrace | OnsTraceQueryByMsgId | get |
Topic
Topic
|
なし |
mq:OnsInstanceBaseInfo |
| mq:SUB | OnsMessagePush | get |
Topic
|
なし |
mq:OnsInstanceBaseInfo |
| mq:ResetConsumerOffset | OnsConsumerResetOffset | get |
Topic
|
なし |
mq:OnsInstanceBaseInfo |
| mq:QueryMessageTrace | OnsMessageTrace | get |
Topic
|
なし |
mq:OnsInstanceBaseInfo |
| mq:QueryTopicSubDetail | OnsTopicSubDetail | get |
Topic
Topic
|
なし |
mq:OnsInstanceBaseInfo |
| mq:CreateGroup | OnsGroupCreate | create |
*Instance
|
なし |
mq:QueryInstanceBaseInfo |
| mq:QueryMessage | OnsMessageGetByMsgId | get |
Topic
|
なし |
mq:OnsInstanceBaseInfo |
| mq:UpdateInstance | OnsInstanceUpdate |
*Instance
*Topic
|
なし |
mq:QueryInstanceBaseInfo |
|
| mq:CreateTopic | OnsTopicCreate |
*Topic
*Topic
|
なし |
mq:QueryInstanceBaseInfo |
|
| mq:DeleteInstance | OnsInstanceDelete |
*Instance
|
なし |
mq:QueryInstanceBaseInfo |
|
| mq:TagResources | TagResources | update |
*All Resource
|
なし | なし |
| mq:QueryInstanceBaseInfo | OnsInstanceInServiceList | list |
Instance
Topic
|
なし |
mq:OnsInstanceBaseInfo |
| mq:QueryTrace | OnsTraceQueryByMsgKey | get |
Topic
Topic
|
なし |
mq:OnsInstanceBaseInfo |
| mq:QueryConsumerAccumulate | OnsConsumerAccumulate | get |
Group
Group
|
なし |
mq:OnsInstanceBaseInfo |
| mq:QueryTrendTopicInputTps | OnsTrendTopicInputTps | get |
Topic
Topic
|
なし |
mq:OnsInstanceBaseInfo |
| mq:QueryMessage | OnsMessageGetByKey | get |
Topic
Topic
|
なし |
mq:OnsInstanceBaseInfo |
| mq:QueryInstanceBaseInfo | OnsInstanceBaseInfo | get |
*Instance
|
なし | なし |
| mq:CreateInstance | OnsInstanceCreate | create |
*All Resource
*Topic
|
なし |
mq:QueryInstanceBaseInfo |
| mq:GetTraceResult | OnsTraceGetResult | get |
*Topic
|
なし | なし |
リソース (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 |
| Group |
|
| Topic |
|
| Instance |
|
条件 (Condition)
では、プロダクトレベルの条件キーは定義されていません。その代わりに、Alibaba Cloud 共通条件キーを使用してアクセスを制御できます。詳細については、「共通条件キー」をご参照ください。
カスタム RAM ポリシーの作成方法
カスタムポリシーを作成し、RAM ユーザー、RAM ユーザーグループ、または RAM ロールに付与できます。詳細については、以下をご参照ください。