Terraformのimport機能を使って既存のVPCとサブネットをTerraformで管理できるようにする

Terraformのimport機能を使って既存のVPCとサブネットをTerraformで管理できるようにする:


はじめに

本記事では、Terraformのimport機能を使って、手動で構築された既存のVPCとサブネットをTerraformで管理できるようにする手順を記載しています。


前提条件

Terraformはインストールされていることとする。

$ terraform --version 
Terraform v0.11.8 
下記の構成図のVPCとサブネットをサンプルとする。


68747470733a2f2f71696974612d696d6167652d



手順

作業ディレクトリに、各設定ファイルを準備する。

( variables.tf 内の各変数の値とNameTagの有無は、適宜、既存の環境に合わせて下さい。)

$ tree terraform/ 
terraform/ 
├── aws.tf 
├── terraform.tfvars 
├── variables.tf 
└── vpc.tf 
terraform.tfvars
aws_access_key = "アクセスキー" 
aws_secret_key = "シークレットキー" 
aws_region = "ap-northeast-1" 
aws.tf
provider "aws" { 
  access_key = "${var.aws_access_key}" 
  secret_key = "${var.aws_secret_key}" 
  region     = "${var.aws_region}" 
  version    = "~> 1.0" 
} 
variables.tf
## AWS 
variable "aws_access_key" {} 
 
variable "aws_secret_key" {} 
 
variable "aws_region" { 
  default = "ap-northeast-1" 
} 
 
data "aws_caller_identity" "self" {} 
 
## VPC CIDR 
variable "vpc_cidr" { 
  default = "10.1.0.0/16" 
} 
 
## VPC Name Tag 
variable "vpc_name_tag" { 
  default = "terraform-import-vpc" 
} 
 
## Subnet 
variable "subnet_cidr" { 
  type = "map" 
 
  default = { 
    public-a  = "10.1.10.0/24" 
    public-c  = "10.1.20.0/24" 
    private-a = "10.1.100.0/24" 
    private-c = "10.1.200.0/24" 
  } 
} 
 
## Subnet Name Tag 
variable "subnet_name_tag" { 
  type = "map" 
 
  default = { 
    public-a  = "terraform-import-public-subnet-a" 
    public-c  = "terraform-import-public-subnet-c" 
    private-a = "terraform-import-private-subnet-a" 
    private-c = "terraform-import-private-subnet-c" 
  } 
} 
vpc.tf
# VPC 
resource "aws_vpc" "vpc" { 
  cidr_block = "${var.vpc_cidr}" 
 
  tags { 
    Name = "${var.vpc_name_tag}" 
  } 
} 
 
# Subnet 
resource "aws_subnet" "public-a" { 
  vpc_id            = "${aws_vpc.vpc.id}" 
  cidr_block        = "${var.subnet_cidr["public-a"]}" 
  availability_zone = "ap-northeast-1a" 
 
  tags { 
    Name = "${var.subnet_name_tag["public-a"]}" 
  } 
} 
 
resource "aws_subnet" "public-c" { 
  vpc_id            = "${aws_vpc.vpc.id}" 
  cidr_block        = "${var.subnet_cidr["public-c"]}" 
  availability_zone = "ap-northeast-1c" 
 
  tags { 
    Name = "${var.subnet_name_tag["public-c"]}" 
  } 
} 
 
resource "aws_subnet" "private-a" { 
  vpc_id            = "${aws_vpc.vpc.id}" 
  cidr_block        = "${var.subnet_cidr["private-a"]}" 
  availability_zone = "ap-northeast-1a" 
 
  tags { 
    Name = "${var.subnet_name_tag["private-a"]}" 
  } 
} 
 
resource "aws_subnet" "private-c" { 
  vpc_id            = "${aws_vpc.vpc.id}" 
  cidr_block        = "${var.subnet_cidr["private-c"]}" 
  availability_zone = "ap-northeast-1c" 
 
  tags { 
    Name = "${var.subnet_name_tag["private-c"]}" 
  } 
} 
下記コマンドで、Terraformの作業ディレクトリを初期化します。

$ terraform init 
 
Initializing provider plugins... 
- Checking for available provider plugins on https://releases.hashicorp.com... 
- Downloading plugin for provider "aws" (1.58.0)... 
 
Terraform has been successfully initialized! 
下記コマンドで、既存のVPCをimportします。

terraform import aws_vpc.vpc [VPCのID] 
下記コマンドで、既存のサブネットをimportします。

terraform import aws_subnet.public-a [Public Subnet A の ID] 
terraform import aws_subnet.public-c [Public Subnet C の ID] 
terraform import aws_subnet.private-a [Private Subnet A の ID] 
terraform import aws_subnet.private-c [Private Subnet C の ID] 
terraform.tfstateファイルが作成されます。

$ tree terraform/ 
terraform/ 
├── aws.tf 
├── terraform.tfstate 
├── terraform.tfstate.backup 
├── terraform.tfvars 
├── variables.tf 
└── vpc.tf 
下記コマンドで、差分がないか確認し、下記メッセージが表示されれば、完了です。

$ terraform plan 
 
No changes. Infrastructure is up-to-date. 

コメント

このブログの人気の投稿

投稿時間:2021-06-17 05:05:34 RSSフィード2021-06-17 05:00 分まとめ(1274件)

投稿時間:2021-06-20 02:06:12 RSSフィード2021-06-20 02:00 分まとめ(3871件)

投稿時間:2020-12-01 09:41:49 RSSフィード2020-12-01 09:00 分まとめ(69件)