VPC リソースのタグの作成と管理
VPC ネットワークは、Resource Manager タグをサポートする次のリソースを使用します。
Resource Manager タグはネットワーク タグとは異なります。このドキュメントでは、タグという用語は Resource Manager タグを指します。
タグをサポートするすべてのサービスのリストについては、タグをサポートするサービスをご覧ください。
ファイアウォール ポリシー ルールでタグを使用する方法については、ファイアウォールのタグをご覧ください。
タグについて
タグは、Trusted Cloud by S3NS内のリソースに適用できる Key-Value ペアです。タグを使用すると、リソースに特定のタグが付加されているかどうかに基づいて、条件付きでポリシーの許可や拒否を行うことができます。たとえば、リソースに特定のタグがあるかどうかに基づいて、Identity and Access Management(IAM)のロールを条件付きで付与できます。タグの詳細については、タグの概要をご覧ください。
タグは、タグと Trusted Cloud by S3NS リソースを結びつけるタグ バインディング リソースを作成することによって、リソースに適用されます。
自動化と課金の目的で Virtual Private Cloud 内の VPC リソースをグループ化するには、ラベルを使用します。タグとラベルは互いに独立しているので、リソースにタグとラベルの両方を使用できます。必要な権限
必要な権限は、実行する必要があるアクションによって異なります。
これらの権限を取得するには、リソース階層の適切なレベルで推奨されているロールの付与を管理者に依頼してください。
タグを表示する
タグの定義とリソースに適用されているタグを確認するには、タグ閲覧者のロール(roles/resourcemanager.tagViewer
)、または次の権限を含む別のロールが必要です。
必要な権限
resourcemanager.tagKeys.get
resourcemanager.tagKeys.list
resourcemanager.tagValues.list
resourcemanager.tagValues.get
- 該当するリソースタイプに対する
listTagBindings
。たとえば、Compute Engine インスタンスに適用されているタグを表示する場合はcompute.instances.listTagBindings
。 listEffectiveTags
(該当するリソースタイプに対する)。たとえば、
compute.instances.listEffectiveTags
は、Compute Engine インスタンスに付加されたすべてのタグを表示するか、そのインスタンスに継承されたすべてのタグを表示します。組織レベルでタグを表示するには、組織リソースに対する組織閲覧者のロール(roles/resourcemanager.organizationViewer
)が必要です。
タグを管理する
タグの定義を作成、更新、削除するには、タグ管理者ロール(roles/resourcemanager.tagAdmin
)か、次の権限を持つ別のロールが必要です。
必要な権限
resourcemanager.tagKeys.create
resourcemanager.tagKeys.update
resourcemanager.tagKeys.delete
resourcemanager.tagKeys.list
resourcemanager.tagKeys.get
resourcemanager.tagKeys.getIamPolicy
resourcemanager.tagKeys.setIamPolicy
resourcemanager.tagValues.create
resourcemanager.tagValues.update
resourcemanager.tagValues.delete
resourcemanager.tagValues.list
resourcemanager.tagValues.get
resourcemanager.tagValues.getIamPolicy
resourcemanager.tagValues.setIamPolicy
組織レベルでタグを管理するには、組織リソースに対する組織閲覧者のロール(roles/resourcemanager.organizationViewer
)が必要です。
リソースのタグを管理する
リソースに適用されたタグを追加または削除するには、タグユーザー ロール(roles/resourcemanager.tagUser
)か、タグ値とタグ値が適用されているリソースに対して同等の権限を持つ別のロールが必要です。タグユーザー ロールには次の権限が含まれます。
必要な権限
- タグ値を適用するリソースに対して必要な権限
- リソース固有の
createTagBinding
権限(Compute Engine インスタンスのcompute.instances.createTagBinding
など)。 - リソース固有の
deleteTagBinding
権限(Compute Engine インスタンスのcompute.instances.deleteTagBinding
など)。 - タグ値に対して必要な権限:
resourcemanager.tagValueBindings.create
resourcemanager.tagValueBindings.delete
- プロジェクトとタグの定義を閲覧できる権限:
resourcemanager.tagValues.get
resourcemanager.tagValues.list
resourcemanager.tagKeys.get
resourcemanager.tagKeys.list
resourcemanager.projects.get
タグを VPC リソースに適用するには、Compute ネットワーク管理者ロール(roles/compute.networkAdmin
)が必要です。
タグキーとタグ値を作成する
タグを適用する前に、タグを作成してその値を構成する必要があります。タグキーとタグ値を作成する方法については、タグの作成とタグ値の追加をご覧ください。
リソースの作成時にタグを追加する
タグは、ネットワーク、サブネットワーク、ルート、VPC ファイアウォール ルールの作成時に追加できます。リソースの作成時にタグを追加すると、リソースの重要なメタデータをすぐに提供できるだけでなく、整理、費用追跡、ポリシーの自動適用にも役立ちます。
gcloud
リソースの作成時にタグをリソースに付加するには、それぞれの create
コマンドで --resource-manager-tags
フラグを追加します。たとえば、ネットワークにタグを付加するには、次のコマンドを使用します。
gcloud compute networks create NETWORK_NAME \ --resource-manager-tags=tagKeys/TAGKEY_ID=tagValues/TAGVALUE_ID
次のように置き換えます。
NETWORK_NAME
: ネットワークの名前TAGKEY_ID
: タグキー番号の数値 IDTAGVALUE_ID
: 付加されているタグ値の永続的な数値 ID(例:4567890123
)
複数のタグを指定する場合は、タグをカンマで区切ります(例: TAGKEY1=TAGVALUE1,TAGKEY2=TAGVALUE2
)。
API
次の URL に POST
リクエストを送信します。
POST https://compute.googleapis.com/compute/v1/projects/PROJECT/global/networks
リクエスト本文で次の JSON を指定します。
{ "name": "NETWORK_NAME", "params": { "resourceManagerTags": { "tagKeys/TAGKEY_ID": "tagValues/TAGVALUE_ID", }, } // Other fields omitted }
次のように置き換えます。
NETWORK_NAME
: ネットワークの名前TAGKEY_ID
: タグキー番号の数値 IDTAGVALUE_ID
: 付加されているタグ値の永続的な数値 ID(例:4567890123
)
既存のリソースにタグを追加する
既存の VPC リソースにタグを追加する手順は次のとおりです。
gcloud
VPC リソースにタグを付加するには、gcloud resource-manager tags bindings create
コマンドを使用してタグ バインディング リソースを作成する必要があります。
gcloud resource-manager tags bindings create \ --tag-value=TAGVALUE_NAME \ --parent=RESOURCE_ID \ --location=LOCATION
次のように置き換えます。
TAGVALUE_NAME
: 適用されるタグ値の永続 ID または名前空間名(例:tagValues/567890123456
)。-
RESOURCE_ID
はリソースの完全な ID で、リソースのタイプ(//compute.googleapis.com/
)を識別するために API ドメイン名が含まれています。リソースには名前ではなく数値 ID を使用する必要があります。たとえば、サブネット ID の形式は//compute.googleapis.com/projects/123/regions/us-central1/subnetworks/456
のようになります。ネットワーク ID は次のような形式になります。//compute.googleapis.com/projects/123/global/networks/789
LOCATION
: リソースのロケーション。フォルダやプロジェクトなどのグローバル リソースにタグを適用する場合は、このフラグを省略します。リージョン リソースまたはゾーンリソースにタグを適用する場合は、us-central1
(リージョン)やus-central1-a
(ゾーン)などのロケーションを指定する必要があります。
リソースに適用されたタグを一覧表示する
VPC リソースに直接適用されているか、VPC リソースによって継承されているタグ バインディングのリストを表示できます。
gcloud
リソースに適用されたタグ バインディングのリストを取得するには、gcloud resource-manager tags bindings list
コマンドを使用します。
gcloud resource-manager tags bindings list \ --parent=RESOURCE_ID \ --location=LOCATION
次のように置き換えます。
-
RESOURCE_ID
はリソースの完全な ID で、リソースのタイプ(//compute.googleapis.com/
)を識別するために API ドメイン名が含まれています。リソースには名前ではなく数値 ID を使用する必要があります。たとえば、サブネット ID の形式は//compute.googleapis.com/projects/123/regions/us-central1/subnetworks/456
のようになります。ネットワーク ID は次のような形式になります。//compute.googleapis.com/projects/123/global/networks/789
LOCATION
: リソースのロケーション。フォルダやプロジェクトなどのグローバル リソースに適用されているタグを表示する場合は、このフラグを省略します。リージョン リソースまたはゾーンリソースに適用されているタグを表示する場合は、us-central1
(リージョン)やus-central1-a
(ゾーン) などのロケーションを指定する必要があります。
次のようなレスポンスが返されます。
name: tagBindings/%2F%2Fcloudresourcemanager.googleapis.com%2Fprojects%2F7890123456/tagValues/567890123456 tagValue: tagValues/567890123456 resource: //compute.googleapis.com/projects/7890123456/subnetworks/subnetwork-ID
リソースからタグを削除する
VPC リソースに直接適用されたタグを解除できます。継承されたタグは、同じキーと別の値を持つタグを適用することでオーバーライドできますが、削除することはできません。
gcloud
タグ バインディングを削除するには、gcloud resource-manager tags bindings delete
コマンドを使用します。
gcloud resource-manager tags bindings delete \ --tag-value=TAGVALUE_NAME \ --parent=RESOURCE_ID \ --location=LOCATION
次のように置き換えます。
TAGVALUE_NAME
: 適用されるタグ値の永続 ID または名前空間名(例:tagValues/567890123456
)。-
RESOURCE_ID
はリソースの完全な ID で、リソースのタイプ(//compute.googleapis.com/
)を識別するために API ドメイン名が含まれています。リソースには名前ではなく数値 ID を使用する必要があります。たとえば、サブネット ID の形式は//compute.googleapis.com/projects/123/regions/us-central1/subnetworks/456
のようになります。ネットワーク ID は次のような形式になります。//compute.googleapis.com/projects/123/global/networks/789
LOCATION
: リソースのロケーション。フォルダやプロジェクトなどのグローバル リソースにタグを適用する場合は、このフラグを省略します。リージョン リソースまたはゾーンリソースにタグを適用する場合は、us-central1
(リージョン)やus-central1-a
(ゾーン)などのロケーションを指定する必要があります。
タグキーとタグ値を削除する
タグキーまたは値の定義を削除する場合は、VPC リソースからタグの適用が解除されていることを確認してください。タグ定義自体を削除する前に、既存のタグの適用(タグ バインディング)を削除する必要があります。タグキーとタグ値を削除するには、タグの削除をご覧ください。
Identity and Access Management の条件とタグ
タグと IAM Conditions を使用すると、階層内のユーザーに条件付きでロール バインディングを付与できます。条件付きロール バインディングを含む IAM ポリシーが適用されている場合、リソースに適用されたタグを変更または削除すると、そのリソースへのユーザー アクセスを削除できます。詳細については、Identity and Access Management の条件とタグをご覧ください。
次のステップ
- タグをサポートするその他のサービス確認する。
- タグとアクセス制御で、IAM でタグを使用する方法を確認する。