コンテンツにスキップ

template.json@Packer

はじめに

本サイトにつきまして、以下をご認識のほど宜しくお願いいたします。


01. セットアップ

インストール

▼ aptリポジトリから

$ curl -L https://apt.releases.hashicorp.com/gpg | sudo apt-key add -
$ sudo apt-add-repository "deb [arch=amd64] https://apt.releases.hashicorp.com $(lsb_release -cs) main"
$ sudo apt-get update && sudo apt-get install packer


CIによる自動化

▼ GitLab CI

variables:
  AWS_DEFAULT_REGION: "ap-northeast-1"
  AWS_ACCOUNT_ID: "*****"
  AWS_IAM_ROLE: "gitlab-ci-packer"

stages:
  - build

build_ami:
  stage: build
  # CIの実行環境
  image: docker:19.03.0
  # サービスコンテナ
  services:
    - name: docker:19.03.0-dind
  variables:
    GIT_SUBMODULE_STRATEGY: "recursive"
  id_tokens:
    GITLAB_OIDC_TOKEN:
      aud: <GitLabのURL>
  before_script:
    - apt-get update && apt-get install -y git jq awscli
    # クレデンシャルを取得する
    - |
      echo "sleeping random seconds (<15s)"
      sleep $(( $RANDOM % 15 ))
      count=0
      backoff=1
      until STS=($(aws sts assume-role-with-web-identity \
      --role-arn arn:aws:iam::${AWS_ACCOUNT_ID}:role/${AWS_IAM_ROLE} \
      --role-session-name ""<任意のセッション名>" \
      --web-identity-token $GITLAB_OIDC_TOKEN \
      --duration-seconds 1800 \
      --query 'Credentials.[AccessKeyId,SecretAccessKey,SessionToken]' \
      --output text)) || (( count++ >= 5 )); do echo "Retrying: $backoff"; sleep $backoff; (( backoff*=2 )); done
      export AWS_ACCESS_KEY_ID="${STS[0]}"
      export AWS_SECRET_ACCESS_KEY="${STS[1]}"
      export AWS_SESSION_TOKEN="${STS[2]}"
      aws sts get-caller-identity
  script:
    - export SOURCE_IMAGE_ID=$(aws ssm get-parameters --names /aws/service/ami-amazon-linux-latest/al2023-ami-kernel-6.1-x86_64 --region ${AWS_DEFAULT_REGION} --query 'Parameters[0].Value' --output text)
    - echo "source ami-id: $SOURCE_IMAGE_ID"
    # Packerを実行する
    - packer build template.json
    - AMI_NAME="foo-$(date "+%Y-%m-%d")"
    - AMI_ID=$(aws ec2 describe-images --region ${AWS_DEFAULT_REGION} --owners self --filters "Name=name,Values=${AMI_NAME}" --query 'Images[*][ImageId]' --output text)
    - SOURCE_IMAGE_NAME=$(git tag -l $CI_COMMIT_TAG -n | awk '{print $2}' | jq -r .image_name)
    - echo $SOURCE_IMAGE_NAME
  rules:
    - if: $CI_COMMIT_TAG
    - when: manual


02. builders

buildersとは

作成するマシンイメージやコンテナイメージの内容を設定する。


typeがamazon-ebsの場合

▼ ami_name

AWS AMIの名前を設定する。

{"builders": [{"type": "amazon-ebs", "ami_name": "bar-ami"}]}

▼ ami_users

{"builders": [{"type": "amazon-ebs", "ami_users": "<AWSアカウントID>"}]}

▼ ena_support

{"builders": [{"type": "amazon-ebs", "ena_support": "true"}]}

▼ encrypt_boot

{"builders": [{"type": "amazon-ebs", "encrypt_boot": "false"}]}

▼ force_deregister

同じ名前のマシンイメージが存在する場合に、既存のマシンイメージを登録解除してからこれを作成するか否か、を設定する。

Packerの作成するマシンイメージの名前は、ランダム値をつけない限り、常に同じである。

マシンイメージの名前の重複を許可しないプロバイダー (例:AWS) では、1個の名前のマシンイメージを一回しか作成できないことになってしまう。

そういった場合に必要になる。

{"builders": [{"type": "amazon-ebs", "force_deregister": "true"}]}

▼ instance_type

{"builders": [{"type": "amazon-ebs", "instance_type": "t2.micro"}]}

▼ launch_block_device_mappings

EC2に紐付けるルートデバイスボリュームを設定する。

{"builders": [{"type": "amazon-ebs", "launch_block_device_mappings": [
            {
              # ルートボリューム
              "device_name": "/dev/xvda",
              "volume_type": "gp2",
              # AWS AMIの作成後に、元となったEC2のボリュームを削除する
              "delete_on_termination": "true",
              "volume_size": "300",
            },
          ]}]}

▼ region

AWS AMIを作成するリージョンを設定する。

{"builders": [{"type": "amazon-ebs", "region": "ap-northeast-1"}]}

▼ snapshot_users

{"builders": [{"type": "amazon-ebs", "snapshot_users": "<AWSアカウントID>"}]}

▼ source_ami

AWS AMIの基とするAWS AMI (例:Amazon Linux 2 AMI) を設定する。

{"builders": [{"type": "amazon-ebs", "source_ami": "ami-0b7546e839d7ace12"}]}

▼ ssh_username

EC2へのSSH公開鍵認証時に使用するユーザー名を設定する。

{"builders": [{"type": "amazon-ebs", "ssh_username": "ec2-user"}]}

▼ temporary_key_pair_type

暗号化キーの種類を設定する。

{"builders": [{"type": "amazon-ebs", "temporary_key_pair_type": "rsa"}]}


03. provisioners

type

▼ typeとは

サーバー/コンテナのプロビジョナーを設定する。


ansibleの場合

▼ playbook_file

{"provisioners": [{"type": "ansible", "playbook_file": "./playbook.yml"}]}

▼ user

{"provisioners": [{"type": "ansible", "user": "ec2-user"}]}


shellの場合

▼ inline

{"provisioners": [{"type": "shell", "inline": ["echo Hello World"]}]}


04. variables

variablesとは

ファイル内で使用する変数を設定する。

{
  "variables": {"region": "ap-northeast-1"},
  "builders": [{"region": "{{ user `region` }}"}],
}