Files
dsk-iac/packer/build_ami_security/docker-ubuntu.pkr.hcl
2023-06-20 19:51:12 +09:00

50 lines
1.1 KiB
HCL

packer {
required_plugins {
amazon = {
version = ">= 0.0.2"
source = "github.com/hashicorp/amazon"
}
}
}
variable "ami_prefix" {
type = string
default = "datasaker-node-ubuntu2004"
}
locals {
timestamp = regex_replace(timestamp(), "[- TZ:]", "")
}
# source 블록에는 실제 빌드할 이미지에 대한 스펙을 정의
source "amazon-ebs" "datasaker-node-ubuntu2004" {
ami_name = "${var.ami_prefix}-${local.timestamp}"
instance_type = "t3.small"
region = "ap-northeast-2"
source_ami_filter {
filters = {
image-id = "ami-0be886bd314f8bd39"
root-device-type = "ebs"
virtualization-type = "hvm"
}
most_recent = true
owners = ["099720109477"]
}
tags = {
source_ami_name = "{{ .SourceAMIName }}"
}
ssh_username = "ubuntu"
}
build {
name = "datasaker-packer"
sources = ["source.amazon-ebs.datasaker-node-ubuntu2004"]
provisioner "ansible" {
playbook_file = "../ansible/docker_roles.yaml"
user = "ubuntu"
extra_arguments = ["--become"]
ansible_env_vars = ["ANSIBLE_HOST_KEY_CHECKING=False"]
}
}