AWS Step не может правильно вызвать пакетное задание AWS со сложными параметрами

У меня есть существующая оркестровка AWS Steps, которая выполняет пакетное задание AWS через lambdas. Однако недавно AWS добавила возможность прямого вызова других сервисов, таких как AWS Batch, с шага. Я стремлюсь использовать эту новую функциональность, но не могу заставить ее работать.

https://docs.aws.amazon.com/step-functions/latest/dg/connectors-batch.html

Итак, мой новый шаг, который я хочу использовать для вызова Batch.

"File Copy": {
  "Type": "Task",
  "Resource": "arn:aws:states:::batch:submitJob.sync",
  "Parameters": {
     "JobName": "MyBatchJob",
     "JobQueue": "MySecondaryQueue",
     "ContainerOverrides.$": "$.lts_job_container_overrides",
     "JobDefinition.$": "$.lts_job_job_definition",
  },
  "Next": "Upload Start"
}

Обратите внимание, что я пытаюсь использовать $. Синтаксис JSONpath, чтобы динамически передавать параметры через шаги.

Когда даны следующие входные данные

"lts_job_container_overrides": {
  "environment": [
    {
      "name": "MY_ENV_VARIABLE",
      "value": "XYZ"
    },
  ],
  "command": [
    "/app/file_copy.py"
  ]
},
"lts_job_job_definition": "MyBatchJobDefinition"

Я ожидал, что значения среды и команд будут переданы в соответствующий параметр (ContainerOverrides) в AWS Batch. Вместо этого кажется, что AWS Steps пытается выдвинуть их в качестве параметров верхнего уровня, а затем жалуется, что они недействительны.

{
 "error": "States.Runtime",
 "cause": "An error occurred while executing the state 'File Copy' 
 (entered at the event id #29). The Parameters 
 '{\"ContainerOverrides\":{\"environment\": 
 [{\"name\":\"MY_ENV_VARIALBE\",\"value\":\"XYZ\"}],\"command\": 
 [\"/app/file_copy.py\"]},\"JobDefinition\":\"MyBatchJobDefinition\"}' 
 could not be used to start the Task: [The field 'environment' is not 
 supported by Step Functions, The field 'command' is not supported by 
 Step Functions]"
}

Как я могу помешать AWS Steps пытаться интерпретировать значения, которые я пытаюсь передать в AWS Batch?


Я попытался извлечь путь JSON из смеси и просто статически указать ContainerProperties (даже если этот долгосрочный период не будет решением). Но даже тогда я сталкиваюсь с проблемами.

"ContainerOverrides": {
   "environment": [
    {
      "name": "RUN_ID",
      "value": "xyz"
    }
   ],
    "command": "/app/file_copy.py"
   }

В этом случае сами шаги отклоняет файл определения при загрузке.

Invalid State Machine Definition: 'SCHEMA_VALIDATION_FAILED: The field 
'environment' is not supported by Step Functions at /States/File 
Copy/Parameters, SCHEMA_VALIDATION_FAILED: The field 'command' is not  
supported by Step Functions at /States/File Copy/Parameters'

Так что просто кажется, что ContainerOverrides проблематично поставить? Я неправильно понял, как это предполагается использовать в этом сценарии?


Вышеупомянутая проблема была решена (согласно ответу ниже) в документации пакета AWS - AWS добавила следующее примечание:

Заметка

Параметры в пошаговых функциях выражаются в CamelCase, даже если API-интерфейс нативного сервиса - pascalCase.

1 ответ

Решение

Это должно работать, я проверил, кажется, работает нормально для меня. И то и другое Environment и его объектные ключи и Command должен быть заглавной буквой.

{
   "StartAt": "AWS Batch: Manage a job",
   "States": {
      "AWS Batch: Manage a job": {
         "Type": "Task",
         "Resource": "arn:aws:states:::batch:submitJob.sync",
         "Parameters": {
            "JobName": "test",
            "JobDefinition": "jobdef",
            "JobQueue": "testq",
            "ContainerOverrides": {
               "Command": [
                  "/app/file_copy.py"
               ],
               "Environment": [
                  {
                     "Name": "MY_ENV_VARIABLE",
                     "Value": "XYZ"
                  }
               ]            
            }
         },
         "End": true
      }
   }
}
Другие вопросы по тегам