123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174 |
- packer {
- required_plugins {
- amazon = {
- version = ">= 0.0.2"
- source = "github.com/hashicorp/amazon"
- }
- }
- }
- variable "runner_version" {
- description = "The version (no v prefix) of the runner software to install https://github.com/actions/runner/releases"
- type = string
- default = "2.286.1"
- }
- variable "region" {
- description = "The region to build the image in"
- type = string
- default = "eu-west-1"
- }
- variable "security_group_id" {
- description = "The ID of the security group Packer will associate with the builder to enable access"
- type = string
- default = null
- }
- variable "subnet_id" {
- description = "If using VPC, the ID of the subnet, such as subnet-12345def, where Packer will launch the EC2 instance. This field is required if you are using an non-default VPC"
- type = string
- default = null
- }
- variable "associate_public_ip_address" {
- description = "If using a non-default VPC, there is no public IP address assigned to the EC2 instance. If you specified a public subnet, you probably want to set this to true. Otherwise the EC2 instance won't have access to the internet"
- type = string
- default = null
- }
- variable "instance_type" {
- description = "The instance type Packer will use for the builder"
- type = string
- default = "m3.medium"
- }
- variable "root_volume_size_gb" {
- type = number
- default = 8
- }
- variable "ebs_delete_on_termination" {
- description = "Indicates whether the EBS volume is deleted on instance termination."
- type = bool
- default = true
- }
- variable "global_tags" {
- description = "Tags to apply to everything"
- type = map(string)
- default = {}
- }
- variable "ami_tags" {
- description = "Tags to apply to the AMI"
- type = map(string)
- default = {}
- }
- variable "snapshot_tags" {
- description = "Tags to apply to the snapshot"
- type = map(string)
- default = {}
- }
- variable "custom_shell_commands" {
- description = "Additional commands to run on the EC2 instance, to customize the instance, like installing packages"
- type = list(string)
- default = []
- }
- source "amazon-ebs" "githubrunner" {
- ami_name = "github-runner-amzn2-x86_64-${formatdate("YYYYMMDDhhmm", timestamp())}"
- instance_type = var.instance_type
- region = var.region
- security_group_id = var.security_group_id
- subnet_id = var.subnet_id
- associate_public_ip_address = var.associate_public_ip_address
- source_ami_filter {
- filters = {
- name = "amzn2-ami-kernel-5.*-hvm-*-x86_64-gp2"
- root-device-type = "ebs"
- virtualization-type = "hvm"
- }
- most_recent = true
- owners = ["137112412989"]
- }
- ssh_username = "ec2-user"
- tags = merge(
- var.global_tags,
- var.ami_tags,
- {
- OS_Version = "amzn2"
- Release = "Latest"
- Base_AMI_Name = "{{ .SourceAMIName }}"
- })
- snapshot_tags = merge(
- var.global_tags,
- var.snapshot_tags,
- )
- launch_block_device_mappings {
- device_name = "/dev/xvda"
- volume_size = "${var.root_volume_size_gb}"
- volume_type = "gp3"
- delete_on_termination = "${var.ebs_delete_on_termination}"
- }
- }
- build {
- name = "githubactions-runner"
- sources = [
- "source.amazon-ebs.githubrunner"
- ]
- provisioner "shell" {
- environment_vars = []
- inline = concat([
- "sudo yum update -y",
- "sudo yum install -y amazon-cloudwatch-agent curl jq git",
- "sudo amazon-linux-extras install docker",
- "sudo systemctl enable docker.service",
- "sudo systemctl enable containerd.service",
- "sudo service docker start",
- "sudo usermod -a -G docker ec2-user",
- ], var.custom_shell_commands)
- }
- provisioner "file" {
- content = templatefile("../install-runner.sh", {
- install_runner = templatefile("../../modules/runners/templates/install-runner.sh", {
- ARM_PATCH = ""
- S3_LOCATION_RUNNER_DISTRIBUTION = ""
- RUNNER_ARCHITECTURE = "x64"
- })
- })
- destination = "/tmp/install-runner.sh"
- }
- provisioner "shell" {
- environment_vars = [
- "RUNNER_TARBALL_URL=https://github.com/actions/runner/releases/download/v${var.runner_version}/actions-runner-linux-x64-${var.runner_version}.tar.gz"
- ]
- inline = [
- "sudo chmod +x /tmp/install-runner.sh",
- "echo ec2-user > /tmp/install-user.txt",
- "sudo RUNNER_ARCHITECTURE=x64 RUNNER_TARBALL_URL=$RUNNER_TARBALL_URL /tmp/install-runner.sh"
- ]
- }
- provisioner "file" {
- content = templatefile("../start-runner.sh", {
- start_runner = templatefile("../../modules/runners/templates/start-runner.sh", {})
- })
- destination = "/tmp/start-runner.sh"
- }
- provisioner "shell" {
- inline = [
- "sudo mv /tmp/start-runner.sh /var/lib/cloud/scripts/per-boot/start-runner.sh",
- "sudo chmod +x /var/lib/cloud/scripts/per-boot/start-runner.sh",
- ]
- }
- }
|