Я использую Terraform (вызывается через Terragrunt, если это актуально), чтобы создать экземпляр из AMI и смонтировать существующий том:
resource "aws_instance" "jenkins_master_with_snap" {
count = "${var.master_with_snapshot}"
ami = "${var.jenkins_ami}"
instance_type = "${var.jenkins_instance_type}"
iam_instance_profile = "${data.terraform_remote_state.global.jenkins_profile_name}"
subnet_id = "${data.aws_subnet.jenkins_subnet_with_snap.id}"
key_name = "${var.key_name}"
vpc_security_group_ids = [
"${aws_security_group.jenkins_master_target_sg.id}",
"${data.terraform_remote_state.cicd.cicd_sg_ipa}"
]
ebs_block_device {
snapshot_id = "${var.master_snapshot_id}"
device_name = "${var.jenkins_volume_device}"
volume_type = "gp2"
}
}
Стоит отметить, что AMI, использованный для создания этого ресурса, уже имеет привязанный к нему моментальный снимок из процесса сборки, поэтому этот ресурс в основном просто заменяет его другим снимком. Я не уверен, вот почему у меня проблема или нет.
Я использую полученные атрибуты ресурса для заполнения шаблона Python, который будет заархивирован и загружен как лямбда-функция. Скрипт Python требует volume-id
от блочного устройства EBS этого экземпляра.
data "template_file" "ebs_backup_lambda_with_snapshot_template" {
count = "${var.master_with_snapshot}"
template = "${file("${path.module}/jenkins_lambda_ebs_backup.py.tpl")}"
vars {
volume_id = "${aws_instance.jenkins_master_with_snap.ebs_block_device.???.volume_id}"
}
}
Об актуальной проблеме: я не знаю, как правильно ссылаться на идентификатор тома в разделе vars
ресурса template_file
выше. Вот результирующее состояние:
ebs_block_device.# = 1
ebs_block_device.1440725774.delete_on_termination = true
ebs_block_device.1440725774.device_name = /dev/xvdf
ebs_block_device.1440725774.encrypted = true
ebs_block_device.1440725774.iops = 900
ebs_block_device.1440725774.snapshot_id = snap-1111111111111
ebs_block_device.1440725774.volume_id = vol-1111111111111
ebs_block_device.1440725774.volume_size = 300
ebs_block_device.1440725774.volume_type = gp2
ebs_optimized = false
root_block_device.# = 1
root_block_device.0.delete_on_termination = false
root_block_device.0.iops = 0
root_block_device.0.volume_id = vol-1111111111111
root_block_device.0.volume_size = 8
root_block_device.0.volume_type = standard
Проблема в том, что индекс тома EBS - это безумное целое число 1440725774
. Я понятия не имею, почему это происходит. В консоли интересует только одна карта в списке:
> aws_instance.jenkins_master_with_snap.ebs_block_device
[
{ delete_on_termination = 1 device_name = /dev/xvdf encrypted = 1 iops = 900 snapshot_id = snap-1111111111111 volume_id = vol-1111111111111 volume_size = 300 volume_type = gp2}
]
И, похоже, единственный способ ссылаться на любой из этих ключей - это напрямую использовать это значение индекса:
> aws_instance.jenkins_master_with_snap.ebs_block_device.1440725774.volume_id
vol-1111111111111
Есть ли способ надежно ссылаться на один элемент в списке, как этот, когда я понятия не имею, каким будет индекс? Я не могу просто жестко закодировать это целое число в ресурс template_file
выше и предположить, что оно будет одинаковым каждый раз. У кого-нибудь есть какие-либо подсказки относительно того, почему это происходит в первую очередь?