1
0

『実践Terraform』でバケット定義の書き方が非推奨と警告されてしまう

Last updated at Posted at 2024-09-05

Terraform初学者です。

実践Terraform』という書籍で勉強しています。

書籍のコードをそのまま記述すると、VSCodeの拡張機能で非推奨と警告されてしまう箇所があったため、備忘録としてまとめます。

この記事におけるバージョンは次のとおりです。

  • Terraform: v1.9.5
  • HashiCorp Terraform(拡張機能): v2.32.2

問題

第6章 ストレージのサンプルコードが対象です。

この章では以下の3つを定義することになっています。

  • プライベートバケット
  • パブリックバケット
  • ログバケット

この3つそれぞれのコードを書籍どおりに書くと非推奨の警告が出てしまいます。

プライベートバケット

書籍のコード

s3.tf
resource "aws_s3_bucket" "private" {
  bucket = "private-pragmatic-terraform"

  versioning {
    enabled = true
  }

  server_side_encryption_configuration {
    rule {
      apply_server_side_encryption_by_default {
        sse_algorithm = "AES256"
      }
    }
  }
}

非推奨の警告

image.png

具体的な警告メッセージ

  • "versioning" is deprecated: Reason: ""
  • "server_side_encryption_configuration" is deprecated: Reason: ""

パブリックバケット

書籍のコード

s3.tf
resource "aws_s3_bucket" "public" {
  bucket = "public-pragmatic-terraform"
  acl    = "public-read"

  cors_rule {
    allowed_origins = ["https://example.com"]
    allowed_methods = ["GET"]
    allowed_headers = [""]
    max_age_seconds = 3000
  }
}

非推奨の警告

image.png

具体的な警告メッセージ

  • "acl" is deprecated: Reason: ""
  • "cors_rule" is deprecated: Reason: ""

ログバケット

書籍のコード

s3.tf
resource "aws_s3_bucket" "alb_log" {
  bucket = "alb-log-pragmatic-terraform"

  lifecycle_rule {
    enabled = true

    expiration {
      days = "180"
    }
  }
}

非推奨の警告

image.png

具体的な警告メッセージ

  • "lifecycle_rule" is deprecated: Reason: ""

原因

terraform-provider-awsのバージョン4.0.0から仕様変更されたようです。

CHANGELOGを確認したところ、以下の5つが独立したリソースとして新たに追加されていました。

  • aws_s3_bucket_versioning
  • aws_s3_bucket_server_side_encryption_configuration
  • aws_s3_bucket_acl
  • aws_s3_bucket_cors_configuration
  • aws_s3_bucket_lifecycle_configuration

それに伴い『実践Terraform』で掲載されている記述方法は非推奨となっています。

S3バケットの設定をより柔軟に行えるよう、独立したリソースとして追加された模様です。

それぞれ次のように書くことで警告が外れました。

プライベートバケット

s3.tf
resource "aws_s3_bucket" "private" {
  bucket = "private-pragmatic-terraform"
}

resource "aws_s3_bucket_versioning" "private" {
  bucket = aws_s3_bucket.private.id
  versioning_configuration {
    status = "Enabled"
  }
}

resource "aws_s3_bucket_server_side_encryption_configuration" "private" {
  bucket = aws_s3_bucket.private.id

  rule {
    apply_server_side_encryption_by_default {
      sse_algorithm = "AES256"
    }
  }
}

パブリックバケット

s3.tf
resource "aws_s3_bucket" "public" {
  bucket = "public-pragmatic-terraform"
}

resource "aws_s3_bucket_acl" "public" {
  bucket = aws_s3_bucket.public.id
  acl    = "public-read"
}

resource "aws_s3_bucket_cors_configuration" "public" {
  bucket = aws_s3_bucket.public.id

  cors_rule {
    allowed_origins = ["https://example.com"]
    allowed_methods = ["GET"]
    allowed_headers = ["*"]
    max_age_seconds = 3000
  }
}

ログバケット

s3.tf
resource "aws_s3_bucket" "alb_log" {
  bucket = "alb-log-pragmatic-terraform"
}

resource "aws_s3_bucket_lifecycle_configuration" "alb_log" {
  bucket = aws_s3_bucket.alb_log.id

  rule {
    id     = "log_expiration"
    status = "Enabled"

    expiration {
      days = 180
    }
  }
}

おわりに

実践Terraform』はとてもわかりやすいため、初学者にもおすすめです。

ただし出版が2019年なので現在とは異なる点もあります。

今後もそういった箇所が見つかったら、適宜調べてさらにTerraformの理解を深めていきたいと思います。

また、この記事に誤りがありましたらコメントにて教えていただけますと幸いです。

参考資料

1
0
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
1
0