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.
Copia de CSV datos a gran escala mediante Distributed Map in Step Functions
Este tutorial le ayuda a empezar a utilizar el estado Map
en modo distribuido. Un estado Map
establecido en Distributed se conoce como estado Map Distributed. El estado Distributed Map se utiliza en los flujos de trabajo para iterar sobre orígenes de datos de Amazon S3 a gran escala. El estado Map
ejecuta cada iteración como una ejecución de flujo de trabajo secundario, lo que permite una alta simultaneidad. Para obtener más información sobre el modo distribuido, consulte Estado Map en modo distribuido.
En este tutorial, utilizará el estado del mapa distribuido para recorrer en iteración un CSV archivo de un bucket de Amazon S3. A continuación, devuelve su contenido, junto con el ARN de la ejecución de un flujo de trabajo secundario, en otro bucket de Amazon S3. Comience por crear un prototipo de flujo de trabajo en Workflow Studio. A continuación, establece el modo de procesamiento del Map estado en Distribuido, especifica el CSV archivo como conjunto de datos y proporciona su ubicación al Map
estado. También debe especificar el tipo de flujo de trabajo para las ejecuciones del flujo de trabajo secundario en las que el estado Distributed Map comienza como Rápido.
Además de estos ajustes, también debe especificar otras configuraciones, como el número máximo de ejecuciones simultáneas de flujos de trabajo secundarios y la ubicación para exportar el resultado de Map
, para el flujo de trabajo de ejemplo utilizado en este tutorial.
Requisitos previos
Sube un CSV archivo a un bucket de Amazon S3. Debe definir una fila de encabezados dentro del CSV archivo. Para obtener información sobre los límites de tamaño impuestos al CSV archivo y cómo especificar la fila de encabezado, consulteCSVarchivo en un bucket de Amazon S3.
Cree otro bucket de Amazon S3 y una carpeta dentro del mismo para exportar el resultado del estado
Map
.
importante
Asegúrese de que sus depósitos de Amazon S3 estén en el mismo lugar Cuenta de AWS y Región de AWS como tu máquina de estados.
Paso 1: Crear el prototipo de flujo de trabajo
En este paso, creará el prototipo para el flujo de trabajo de utilizando Workflow Studio. Workflow Studio es un diseñador visual de flujos de trabajo disponible en la consola de Step Functions. Puede elegir el estado y la API acción necesarios en las pestañas Flujo y Acciones, respectivamente. Utilizará la característica de arrastrar y soltar de Workflow Studio para crear el prototipo del flujo de trabajo.
Abra la consola de Step Functions
y seleccione Crear máquina de estado. En el cuadro de diálogo Elegir una plantilla, seleccione En blanco.
-
Seleccione Seleccionar para abrir Workflow StudioModo Diseño.
Desde la pestaña Flujo, arrastre un estado Map al estado vacío con la etiqueta Arrastrar la primera acción aquí.
En la pestaña Configuración, en Nombre de estado, escriba
Process data
.En la pestaña Acciones, arrastre un AWS Lambda Invoque API la acción y colóquela dentro del estado Procesar datos.
-
Cambie el nombre del AWS Lambda Invoque el estado a.
Process CSV data
Paso 2: Configurar los campos necesarios para el estado Map
En este paso, configurará los siguientes campos obligatorios del estado Distributed Map:
ItemReader— Especifica el conjunto de datos y su ubicación desde la que el
Map
estado puede leer la entrada.ItemProcessor: especifica los siguientes valores:
ProcessorConfig
, defina los valoresMode
yExecutionType
enDISTRIBUTED
yEXPRESS
, respectivamente. Esto establece el modo de procesamiento del estadoMap
y el tipo de flujo de trabajo para las ejecuciones de flujos de trabajo secundarios en las que se inicia el estado Distributed Map.StartAt
: el primer estado del flujo de trabajo de Map.States
: define el flujo de trabajo de Map, que consiste en un conjunto de pasos que se deben repetir en cada ejecución del flujo de trabajo secundario.
ResultWriter— Especifica la ubicación de Amazon S3 en la que Step Functions escribe los resultados del estado del mapa distribuido.
importante
Asegúrese de que el bucket de Amazon S3 que utiliza para exportar los resultados de un Map Run esté en el mismo lugar. Cuenta de AWS y Región de AWS como tu máquina de estados. De lo contrario, la ejecución de la máquina de estado fallará y se producirá el error
States.ResultWriterFailed
.
Para configurar los campos necesarios:
Elija el estado Procesar datos y haga lo siguiente en la pestaña Configuración; haga lo siguiente:
Para Modo de procesamiento, elija Distribuido.
En Origen del elemento, elija Amazon S3 y, a continuación, elija el CSVarchivo en S3 en la lista desplegable Origen del elemento de S3.
Haga lo siguiente para especificar la ubicación en Amazon S3 del CSV archivo:
Para Objeto S3, seleccione Introducir bucket y clave en la lista desplegable.
En Bucket, introduzca el nombre del bucket de Amazon S3, que contiene el CSV archivo. Por ejemplo,
amzn-s3-demo-source-bucket
.En Key, introduzca el nombre del objeto de Amazon S3 en el que guardó el CSV archivo. También debe especificar el nombre del CSV archivo en este campo. Por ejemplo,
csvDataset/ratings.csv
.
En el CSV caso de los archivos, también debe especificar la ubicación del encabezado de la columna. Para ello, elija Configuración adicional y, a continuación, para la ubicación del CSV encabezado, mantenga la selección predeterminada de Primera fila si la primera fila del CSV archivo es el encabezado. De lo contrario, elija Dado para especificar el encabezado dentro de la definición de la máquina de estado. Para obtener más información, consulte
ReaderConfig
.Para Tipo de ejecución secundaria, elija Express.
En Exportar ubicación, para exportar los resultados de Map Run a una ubicación específica de Amazon S3, elija Exportar la salida del estado Map a Amazon S3.
Haga lo siguiente:
Para Bucket de S3, seleccione Introducir el nombre y el prefijo del bucket en la lista desplegable.
En bucket, escriba el nombre del bucket de Amazon S3 en el que desea exportar los resultados. Por ejemplo,
mapOutputs
.En Prefijo, introduzca el nombre de la carpeta en la que desee guardar los resultados. Por ejemplo,
resultData
.
Paso 3: Configurar opciones adicionales
Además de los ajustes necesarios para un estado Distributed Map, también puede especificar otras opciones. Estas pueden incluir el número máximo de ejecuciones simultáneas de flujos de trabajo secundarios y la ubicación a la que se debe exportar el resultado del estado Map
.
Seleccione el estado Procesar datos. A continuación, en Fuente de elemento, elija Configuración adicional.
Haga lo siguiente:
Seleccione Modificar elementos con ItemSelector para especificar una JSON entrada personalizada para la ejecución de cada flujo de trabajo secundario.
Introduzca la siguiente JSON entrada:
{
"index.$":
"$$.Map.Item.Index"
,"value.$":
"$$.Map.Item.Value"
}Para obtener información sobre cómo crear una entrada personalizada, consulte
ItemSelector (Mapa)
.
En la Configuración de versión ejecutable, en Límite de simultaneidad, especifique el número de ejecuciones simultáneas del flujo de trabajo secundario que puede iniciar el estado Distributed Map. Por ejemplo, escriba
100
.-
Abra una nueva ventana o pestaña en el navegador y complete la configuración de la función de Lambda que utilizará en este flujo de trabajo, tal y como se explica en Paso 4: Configurar la función de Lambda.
Paso 4: Configurar la función de Lambda
importante
Asegúrese de que su función Lambda esté en el mismo nivel Región de AWS como tu máquina de estados.
-
Abra la consola de Lambda
; y elija Crear función. -
En la página Crear función, elija Diseñar desde cero.
-
En la sección Información básica, configure la función de Lambda:
-
En Nombre de la función, introduzca
distributedMapLambda
. -
En Runtime (Tiempo de ejecución), elija Node.js.
-
Mantenga todas las selecciones predeterminadas y elija Crear función.
-
Tras crear la función Lambda, copie el nombre del recurso de Amazon (ARN) de la función que aparece en la esquina superior derecha de la página. Deberá proporcionar esto en su prototipo de flujo de trabajo. A continuación se muestra un ejemplo: ARN
arn:aws:lambda:us-east-2:123456789012:function:distributedMapLambda
-
-
Copie el siguiente código para la función Lambda y péguelo en la sección Código fuente de la distributedMapLambdapágina.
exports.handler = async function(event, context) { console.log("Received Input:\n", event); return { 'statusCode' : 200, 'inputReceived' : event //returns the input that it received } };
-
Elija Implementar. Una vez implementada la función, elija Probar para ver el resultado de la función de Lambda.
Paso 5: Actualizar el prototipo de flujo de trabajo
En la consola Step Functions, actualizará su flujo de trabajo para añadir las funciones de Lambda. ARN
Vuelva a la pestaña o ventana en la que creó el prototipo del flujo de trabajo.
Seleccione el paso CSVProcesar datos y, en la pestaña Configuración, haga lo siguiente:
En Tipo de integración, elija Optimizado.
En Función de Lambda, empiece a introducir el nombre de la función de Lambda. Elija la función en la lista desplegable que aparece o elija Introducir el nombre de la función e introduzca la función ARN Lambda.
Paso 6: Revisar la definición de Amazon States Language generada automáticamente y guardar el flujo de trabajo
A medida que arrastra y suelta los estados de las pestañas Acción y Flujo al lienzo, Workflow Studio redacta automáticamente la definición de su flujo de trabajo en Amazon States Language en tiempo real. Puede editar esta definición según sea necesario.
-
(Opcional) Seleccione Definición en el Panel de inspectores panel y visualice la definición de la máquina de estado.
sugerencia
También puede ver la ASL definición en Workflow Editor de código Studio. En el editor de código, también puede editar la ASL definición de su flujo de trabajo.
El siguiente código de ejemplo muestra la definición de Amazon States Language generada automáticamente para su flujo de trabajo.
{ "Comment": "Using Map state in Distributed mode", "StartAt": "Process data", "States": { "Process data": { "Type": "Map", "MaxConcurrency": 100, "ItemReader": { "ReaderConfig": { "InputType": "CSV", "CSVHeaderLocation": "FIRST_ROW" }, "Resource": "arn:aws:states:::s3:getObject", "Parameters": { "Bucket": "amzn-s3-demo-source-bucket", "Key": "csvDataset/ratings.csv" } }, "ItemProcessor": { "ProcessorConfig": { "Mode": "DISTRIBUTED", "ExecutionType": "EXPRESS" }, "StartAt": "Process CSV data", "States": { "Process CSV data": { "Type": "Task", "Resource": "arn:aws:states:::lambda:invoke", "OutputPath": "$.Payload", "Parameters": { "Payload.$": "$", "FunctionName": "arn:aws:lambda:us-east-2:123456789012:function:distributedMapLambda" }, "End": true } } }, "Label": "Processdata", "End": true, "ResultWriter": { "Resource": "arn:aws:states:::s3:putObject", "Parameters": { "Bucket": "mapOutputs", "Prefix": "resultData" } }, "ItemSelector": { "index.$": "$$.Map.Item.Index", "value.$": "$$.Map.Item.Value" } } } }
-
Especifique un nombre para la máquina de estado. Para ello, elija el icono de edición situado junto al nombre predeterminado de la máquina de estado MyStateMachine. A continuación, en Configuración de máquina de estado, especifique un nombre en el cuadro Nombre de la máquina de estado.
En este tutorial, ingrese el nombre
DistributedMapDemo
. -
(Opcional) En Configuración de máquina de estado, especifique otros ajustes del flujo de trabajo, como el tipo de máquina de estado y su función de ejecución.
Para este tutorial, mantenga todas las selecciones predeterminadas en Configuración de máquina de estado.
-
En el cuadro de diálogo Confirmar creación de rol, elija Confirmar para continuar.
También puede seleccionar Ver configuración de rol para volver a Configuración de máquina de estado.
nota
Si eliminas el IAM rol que Step Functions crea, Step Functions no podrá volver a crearlo más adelante. Del mismo modo, si modificas el rol (por ejemplo, quitando Step Functions de los principios de la IAM política), Step Functions no podrá restaurar su configuración original más adelante.
Paso 7: Ejecutar la máquina de estado
Una ejecución es una instancia de su máquina de estado en la que ejecuta su flujo de trabajo para realizar tareas.
-
En la DistributedMapDemopágina, selecciona Iniciar la ejecución.
-
En el cuadro de diálogo Iniciar ejecución, haga lo siguiente:
-
(Opcional) Introduzca un nombre de ejecución personalizado para anular el valor predeterminado generado.
ASCIINombres no identificables y registro
Step Functions acepta nombres para máquinas de estados, ejecuciones, actividades y etiquetas que no contengan ASCII caracteres. Como estos personajes no funcionan con Amazon CloudWatch, te recomendamos que utilices solo ASCII caracteres para poder hacer un seguimiento de las métricas CloudWatch.
-
(Opcional) En el cuadro de entrada, introduce los valores de entrada en el JSON formato adecuado para ejecutar tu flujo de trabajo.
-
Seleccione Iniciar ejecución.
-
La consola de Step Functions le dirige a una página cuyo título es su ID de ejecución. Esta página se conoce como Detalles de la ejecución. En esta página, puede revisar los resultados de la ejecución a medida que avanza la ejecución o una vez finalizada.
Para revisar los resultados de la ejecución, elija los estados individuales en la Vista de gráfico y, a continuación, elija las pestañas individuales del panel Detalles del paso para ver los detalles de cada estado, incluidas la entrada, la salida y la definición, respectivamente. Para obtener más información sobre la ejecución que puede ver en la página Detalles de la ejecución, consulte Descripción general de los detalles de ejecución.
Por ejemplo, elija el estado
Map
y, a continuación, elija Map Run para abrir la página de Detalles de Map Run. En esta página, puede ver todos los detalles de ejecución de estado Map Distributed y las ejecuciones del flujo de trabajo secundario que inició. Para obtener información acerca de esta página, consulte Visualización de las ejecuciones del mapa. -