У меня есть переменная, которая представляет собой список карт.
Пример:
processes = [
[
{start_cmd: "a-server-start", attribute2:"type_a"},
{start_cmd: "a-worker-start", attribute2:"type_b"}
{start_cmd: "a--different-worker-start", attribute2:"type_c"}
],
[
{start_cmd: "b-server-start", attribute2:"type_a"},
{start_cmd: "b-worker-start", attribute2:"type_b"}
]
]
На каждой итерации мне нужно извлекать массив карт, затем перебирать этот массив и извлекать значения карты. Как мне добиться этого в терраформе?
Я подумал о том, чтобы иметь два счетчика и выполнить некоторые арифметические действия, чтобы заставить terraform выполнить похожую вложенную итерацию Проверьте ссылку здесь. Но в нашем случае количество карт во внутреннем массиве может варьироваться.
Кроме того, в настоящее время мы используем версию 0.11 terraform, но не возражаем против использования альфа-версии 0.12 terraform, если это возможно в этой версии.
Редактировать:
Добавлено, как я буду использовать эту переменную:
resource “create_application” “applications” {
// Create a resource for every array in the variable processes. 2 in this case
name = ""
migration_command = ""
proc {
// For every map create this attribute for the resource.
name = ““
init_command = “a-server-start”
type = “server”
}
}
Не уверен, что это устраняет требование. Пожалуйста, спросите, если это все еще не ясно.
Я добавил правку для решения этого вопроса
Если я правильно помню из примечаний к выпуску, это впервые включается в 0.12.
Мы просмотрели версию 0.12-beta, но не смогли найти способ сделать это. Если возможно, можете ли вы показать рабочий способ выполнения вложенных итераций с использованием бета-версии 0.12?





Использование терраформ 0.12.x
locals {
processes = [
[
{ start_cmd: "a-server-start", type: "type_a", name: "inglorious bastards" },
{ start_cmd: "a-worker-start", type: "type_b", name: "kill bill" },
{ start_cmd: "a--different-worker-start", type: "type_c", name: "pulp fiction" },
],
[
{ start_cmd: "b-server-start", type: "type_a", name: "inglorious bastards" },
{ start_cmd: "b-worker-start", type: "type_b", name: "kill bill" },
]
]
}
# just an example
data "archive_file" "applications" {
count = length(local.processes)
type = "zip"
output_path = "applications.zip"
dynamic "source" {
for_each = local.processes[count.index]
content {
content = source.value.type
filename = source.value.name
}
}
}
$ terraform apply
data.archive_file.applications[0]: Refreshing state...
data.archive_file.applications[1]: Refreshing state...
Apply complete! Resources: 0 added, 0 changed, 0 destroyed.
Если ресурс create_application существует, его можно смоделировать следующим образом.
resource "create_application" "applications" {
count = length(local.processes)
name = ""
migration_command = ""
dynamic "proc" {
for_each = local.processes[count.index]
content {
name = proc.value.name
init_command = proc.value.start_cmd
type = proc.value.type
}
}
}
Какой вывод вы хотите здесь увидеть?