클라우드 배우기
Terraform S3 구축 및 Dyanmo DB 생성 본문
/backend/main.tf
provider "aws" {
region = "eu-west-2"
}
resource "aws_s3_bucket" "terraform_state" {
bucket = "s3-911031"
}
#s3 버저닝 -> 오래된 상태 파일도 저장
resource "aws_s3_bucket_versioning" "enabled" {
bucket = aws_s3_bucket.terraform_state.id
versioning_configuration {
status = "Enabled"
}
}
#s3 암호화: SSE(서버 측 암호화)
resource "aws_s3_bucket_server_side_encryption_configuration" "default"{
bucket = aws_s3_bucket.terraform_state.id
rule{
apply_server_side_encryption_by_default {
sse_algorithm = "AES256"
}
}
}
# 공개 액세스 차단
resource "aws_s3_bucket_public_access_block" "public_access" {
bucket = aws_s3_bucket.terraform_state.id
block_public_acls = true
block_public_policy = true
ignore_public_acls = true
restrict_public_buckets = true
}
#DynamoDB 생성
resource "aws_dynamodb_table" "terraform_lock" {
name = "911031-dynamodb"
billing_mode = "PAY_PER_REQUEST"
hash_key = "LockID"
attribute {
name = "LockID"
type = "S"
}
}
S3 생성 확인
DynamoDB 생성 확인
s3dp tfstate 파일을 올리기 위한 테라폼 코드
terraform {
required_version = ">= 1.0.0, < 2.0.0"
backend "s3" {
bucket = "s3-911031"
key = "vpc/terraform.tfstate"
region = "eu-west-2"
encrypt = true
dynamodb_table = "911031-dynamodb"
}
}
#Terraform은 상태 파일 락(lock) 관리를 위해 911031-dynamodb라는 DynamoDB 테이블을 사용
'AWS' 카테고리의 다른 글
AWS Lambda (0) | 2024.04.04 |
---|---|
AWS Autoscaling 설정 (0) | 2024.04.03 |
AWS httpd+ wordpress + Aurora RDS (https/loadbalancer) (0) | 2024.04.01 |
SSM-agent 역할 부여 및 IP 개수 증량 (0) | 2024.03.29 |
loadbalancer(gateway/+ 쿠키(stickness) (0) | 2024.01.22 |