Crear un documento de YAML flujo de trabajo - EC2Image Builder

Las traducciones son generadas a través de traducción automática. En caso de conflicto entre la traducción y la version original de inglés, prevalecerá la version en inglés.

Crear un documento de YAML flujo de trabajo

El documento de definición de YAML formato configura los pasos de entrada, salida y flujo de trabajo para las etapas de creación y prueba del proceso de creación de la imagen. Puede empezar con plantillas que incluyan pasos estandarizados, o bien puede empezar desde cero para definir su propio flujo de trabajo. Tanto si utiliza una plantilla como si empieza desde cero, puede personalizar el flujo de trabajo para adaptarlo a sus necesidades.

Estructura de un documento de YAML flujo de trabajo

El documento YAML de flujo de trabajo que Image Builder utiliza para realizar acciones de creación y prueba de imágenes se estructura de la siguiente manera.

Identificación del documento de flujo de trabajo

Identifica de forma única el flujo de trabajo. En esta sección se pueden incluir los siguientes atributos.

Campo

Descripción

Tipo

Obligatoria

Nombre

Nombre del documento de flujos de trabajo.

Cadena

No

description

Descripción del documento.

Cadena

No

schemaVersion

Versión del esquema del documento, actualmente 1.0.

Cadena

Ejemplo

--- name: sample-test-image description: Workflow for a sample image, with extra configuration options exposed through workflow parameters. schemaVersion: 1.0

Parámetros de entrada del documento de trabajo

En esta parte del documento de flujos de trabajo se definen los parámetros de entrada que la persona que llama puede especificar. Si no dispone de ningún parámetro, puede omitir esta sección. Si especifica parámetros, cada parámetro puede incluir los siguientes atributos.

Campo

Descripción

Tipo

Obligatoria

Restricciones

name

El nombre del parámetro.

Cadena

description

Descripción del parámetro.

Cadena

No

predeterminada

Si no se proporciona ningún valor, el valor predeterminado del parámetro. Si no incluye un valor predeterminado en la definición del parámetro, el valor del parámetro es obligatorio en tiempo de ejecución.

Coincide con el tipo de datos del parámetro.

No

type

El tipo de datos del parámetro. Si no incluye el tipo de datos en la definición del parámetro, el tipo del parámetro toma como predeterminado un valor de cadena obligatorio en tiempo de ejecución.

Cadena

El tipo de datos del parámetro debe ser uno de los siguientes:

  • string

  • integer

  • boolean

  • stringList

Ejemplo

Especifique el parámetro en el documento de flujos de trabajo.

parameters: - name: waitForActionAtEnd type: boolean default: true description: "Wait for an external action at the end of the workflow"

Utilice el valor del parámetro en el documento de flujos de trabajo.

$.parameters.waitForActionAtEnd

Pasos del documento de trabajo

Especifica hasta 15 acciones de paso para el flujo de trabajo. Los pasos se ejecutan en el orden en que se definen en el documento de flujos de trabajo. En caso de error, se ejecuta una restauración en orden inverso, empezando por el paso en el que se produjo el error y siguiendo por los pasos anteriores.

Cada paso puede hacer referencia a la salida de cualquier acción de paso anterior. Esto se conoce como encadenamiento o referencia. Para hacer referencia al resultado de una acción de un paso anterior, puede utilizar un JSONPath selector. Por ejemplo:

$.stepOutputs.step-name.output-name

Para obtener más información, consulte Uso de variables dinámicas en el documento de flujos de trabajo.

nota

Aunque el paso en sí no tenga un atributo de salida, todas las salidas de una acción de paso se incluyen en stepOutput para el paso.

Cada paso puede incluir los siguientes atributos.

Campo

Descripción

Tipo

Obligatoria

Valor predeterminado

Restricciones

acción

Acción de flujo de trabajo que realiza este paso.

Cadena

Debe ser una acción de paso admitida para los documentos de flujos de trabajo del Generador de imágenes.

if, seguido de un conjunto de instrucciones condicionales que modifican el operador if.

Las instrucciones condicionales agregan puntos de decisión sobre el flujo de control al cuerpo de los pasos del flujo de trabajo.

Dict

No

El Generador de imágenes admite las siguientes instrucciones condicionales como modificadores del operador if:

  • Condiciones y modificadores de ramificación: if, and, or, not. Las condiciones de ramificación se especifican en una línea por sí mismas.

  • Operadores de comparación: booleanEquals, numberEquals, numberGreaterThan, numberGreaterThanEquals, numberLessThan, numberLessThanEquals, stringEquals.

description

Descripción del paso.

Cadena

No

No se permiten cadenas vacías. Si se incluye, la longitud debe ser de 1 a 1024 caracteres.

inputs

Contiene los parámetros que debe ejecutar la acción del paso. Puede especificar los valores clave como valores estáticos o con una JSONPath variable que se resuelva en el tipo de datos correcto.

Dict

name

El nombre del paso. Este nombre debe ser único dentro del documento de flujos de trabajo.

Cadena

Debe tener entre 3 y 128 caracteres de longitud.

Puede incluir caracteres alfanuméricos y _. Sin espacios.

onFailure

Configura la acción que se debe realizar si el paso produce un error, de la siguiente manera.

Comportamiento
  • Abort: genera un error en el paso, genera un error en el flujo de trabajo y no ejecuta ningún paso restante después del paso con error. Si la restauración está habilitada, esta comienza con el paso con error y continúa hasta que se restauren todos los pasos que la permiten.

  • Continue: genera un error en el paso, pero se siguen ejecutando los pasos restantes después del paso con error. En este caso, no hay ninguna restauración.

Cadena

No

Abort

Abort | Continue

rollbackEnabled

Configura si el paso se restaurará en caso de que se produzca un error. Puede usar un valor booleano estático o una JSONPath variable dinámica que se resuelva en un valor booleano.

Booleano

No

true

true | false

| o una JSONPath variable que se resuelva como verdadera o falsa.

timeoutSeconds

Tiempo máximo, en segundos, que se ejecuta el paso antes de producir un error y volver a intentarlo, si se aplican los reintentos.

Entero

No

Depende del valor predeterminado definido para la acción del paso, si corresponde.

Entre 1 y 86 400 segundos (24 horas como máximo)

Ejemplo

steps: - name: LaunchTestInstance action: LaunchInstance onFailure: Abort inputs: waitFor: "ssmAgent" - name: ApplyTestComponents action: ExecuteComponents onFailure: Abort inputs: instanceId.$: "$.stepOutputs.LaunchTestInstance.instanceId" - name: TerminateTestInstance action: TerminateInstance onFailure: Continue inputs: instanceId.$: "$.stepOutputs.LaunchTestInstance.instanceId" - name: WaitForActionAtEnd action: WaitForAction if: booleanEquals: true value: "$.parameters.waitForActionAtEnd"

Resultados de documentos de flujo de trabajo

Define las salidas del flujo de trabajo. Cada salida es un par de clave-valor que especifica el nombre de la salida y el valor. Puede utilizar las salidas para exportar datos en tiempo de ejecución que puedan utilizar los flujos de trabajo posteriores. Esta sección es opcional.

Cada salida que defina incluye los siguientes atributos.

Campo

Descripción

Tipo

Obligatoria

Nombre

El nombre de la salida. El nombre debe ser único en todos los flujos de trabajo que incluya en la canalización.

Cadena

valor

Valor de la salida. El valor de la cadena puede ser una variable dinámica, como un archivo de salida de una acción de paso. Para obtener más información, consulte Uso de variables dinámicas en el documento de flujos de trabajo.

Cadena

Ejemplo

Cree un ID de imagen de salida para el documento de flujos de trabajo con la salida del paso createProdImage.

outputs: - name: 'outputImageId' value: '$.stepOutputs.createProdImage.imageId'

Consulte la salida del flujo de trabajo en el siguiente flujo de trabajo.

$.workflowOutputs.outputImageId