質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.37%
Terraform

Terraformは、インフラ構築のためのツールです。AWS/DigitalOcean/GoogleCloudといった様々なインフラに対応。インフラ構成のコード管理や変更の作業などの手間を自動化し、インフラ構築の効率化を図ることができます。

AWS(Amazon Web Services)

Amazon Web Services (AWS)は、仮想空間を機軸とした、クラスター状のコンピュータ・ネットワーク・データベース・ストーレッジ・サポートツールをAWSというインフラから提供する商用サービスです。

Q&A

1回答

4574閲覧

Terraform AWSでのデフォルトリージョン以外のリソースの定義方法について

GotHokLin

総合スコア37

Terraform

Terraformは、インフラ構築のためのツールです。AWS/DigitalOcean/GoogleCloudといった様々なインフラに対応。インフラ構成のコード管理や変更の作業などの手間を自動化し、インフラ構築の効率化を図ることができます。

AWS(Amazon Web Services)

Amazon Web Services (AWS)は、仮想空間を機軸とした、クラスター状のコンピュータ・ネットワーク・データベース・ストーレッジ・サポートツールをAWSというインフラから提供する商用サービスです。

0グッド

1クリップ

投稿2022/06/14 12:31

前提

現在、Terraformを利用してAWSのGuardDutyの有効化を行っております。

GuardDutyは有効にできるリージョン全てにおいて有効化しようとしております。
リージョンは複数ありますので、Terraformでのリソース aws_guardduty_detector の設定については、モジュール化しており、リージョンごとにそのモジュールを呼び出しております。

リージョンについては、provider "aws" で地域名をエイリアスとして指定して、モジュールを呼び出す際にそのエイリアスを指定しております。

リージョンの定義とモジュールの呼び出しは以下のようにしております。

# リージョン指定 ## デフォルトリージョン provider "aws" { region = "ap-northeast-1" } ## バージニアリージョン provider "aws" { alias = "virginia" region = "us-east-1" } ## 以下他の地域のリージョンも定義 …… # GuardDuty有効化モジュール呼び出し module "tokyo-gd" { source = "./modules/aws/guardduty" } module "virginia-gd" { source = "./modules/aws/guardduty" providers = { aws = aws.virginia } }

このようにしてapplyしたところ、目的通り、各リージョンでGuardDutyは有効になったのですが、以下のようにWarningが出ました。

Warning: Reference to undefined provider on main.tf line 8, in module "virginia-gd": 8: aws = aws.virginia There is no explicit declaration for local provider name "aws" in module.virginia-gd, so Terraform is assuming you mean to pass a configuration for "hashicorp/aws". If you also control the child module, add a required_providers entry named "aws" with the source address "hashicorp/aws". (and 15 more similar warnings elsewhere)

(上記ではTerraformソース8行目としてWarningが出ており、前述のコードと行数が異なりますが、前述のコードはサンプルで抜き出した物での差異ということでご了承ください)

実現したいこと

Warningですのでそこまで問題はないのかもしれませんが、文面としてはきちんと定義されていないという状況かと思いますので、正しいリージョンの指定を行いたいと考えております。

現在のTerraform、AWSプロバイダのバージョンでの正しいデフォルトではないリージョンの指定の仕方をお教え頂けたら幸いです。

補足情報(FW/ツールのバージョンなど)

Terraform v1.2.2
provider registry.terraform.io/hashicorp/aws v4.18.0

他に必要な情報等ありましたら、コメントでお教えください。追記したいと思います。

以上、よろしくお願いいたします。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

異なるリージョンのリソースを同じtfstateで管理したいときはMultipule Providersの設定を使用します。

alias:Multiple Provider Configurations
How to use multiple AWS providers in a Terraform project

ちょうどこちらの記事でやりたいことを恐らくそのままやっているかと思います。
Terraformで脅威検出サービスAmazon GuardDutyの有効化からAWS ChatbotでのSlack通知フローを構築する
※こちらの記事にはprovidersに個別に値を渡して別々のモジュールとして定義していますが、providersはmapを渡せば良さそうで、まとめて複数のproviderの設定を渡すこともできそうです。
The Module providers Meta-Argument

投稿2022/06/15 00:52

yu_1985

総合スコア7586

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

会員登録して回答してみよう

アカウントをお持ちの方は

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.37%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問