Define a Distributed Mode Map state in the state machine. A `Map` state can be used to run a set of steps for each element of an input array. A Map state will execute the same steps for multiple entries of an array in the state input. While the Parallel state executes multiple branches of steps using the same input, a Map state will execute the same steps for multiple entries of an array in the state input. A `Map` state in `Distributed` mode will execute a child workflow for each iteration of the Map state. This serves to increase concurrency and allows for larger workloads to be run in a single state machine.
import { DistributedMap } from 'aws-cdk-lib/aws-stepfunctions';Or use the module namespace:
import * as stepfunctions from 'aws-cdk-lib/aws-stepfunctions';
// stepfunctions.DistributedMapConfiguration passed to the constructor as DistributedMapProps.
itemBatcherOptionalItemBatcherSpecifies to process a group of items in a single child workflow execution.
Default: - No itemBatcher
itemReaderOptionalIItemReaderItemReader. Configuration for where to read items dataset in S3 to iterate
Default: - No itemReader
labelOptionalstringLabel. Unique name for the Distributed Map state added to each Map Run
Default: - No label
mapExecutionTypeOptionalStateMachineTypeMapExecutionType. The execution type of the distributed map state This property overwrites ProcessorConfig.executionType
Default: StateMachineType.STANDARD
resultWriterOptionalDeprecatedResultWriterConfiguration for S3 location in which to save Map Run results.
Default: - No resultWriter
Deprecated: Use {@link resultWriterV2 }
resultWriterV2OptionalResultWriterV2Configuration for S3 location in which to save Map Run results Enable "@aws-cdk/aws-stepfunctions:useDistributedMapResultWriterV2" feature in the context to use resultWriterV2 Example: stack.node.setContext("@aws-cdk/aws-stepfunctions:useDistributedMapResultWriterV2", true);
Default: - No resultWriterV2
toleratedFailureCountOptionalnumberToleratedFailureCount. Number of failed items to tolerate in a Map Run, as static number
Default: - No toleratedFailureCount
toleratedFailureCountPathOptionalstringToleratedFailureCountPath. Number of failed items to tolerate in a Map Run, as JsonPath
Default: - No toleratedFailureCountPath
toleratedFailurePercentageOptionalnumberToleratedFailurePercentage. Percentage of failed items to tolerate in a Map Run, as static number
Default: - No toleratedFailurePercentage
toleratedFailurePercentagePathOptionalstringToleratedFailurePercentagePath. Percentage of failed items to tolerate in a Map Run, as JsonPath
Default: - No toleratedFailurePercentagePath
StateBasePropscommentOptionalinherited from StateBasePropsstringA comment describing this state.
Default: No comment
queryLanguageOptionalinherited from StateBasePropsQueryLanguageThe name of the query language used by the state. If the state does not contain a `queryLanguage` field, then it will use the query language specified in the top-level `queryLanguage` field.
Default: - JSONPath
stateNameOptionalinherited from StateBasePropsstringOptional name for this state.
Default: - The construct ID will be used as state name
MapBaseOptionsitemSelectorOptionalinherited from MapBaseOptions{ [key: string]: any }The JSON that you want to override your default iteration input (mutually exclusive with `parameters` and `jsonataItemSelector`).
Default: $
jsonataItemSelectorOptionalinherited from MapBaseOptionsstringJsonata expression that evaluates to a JSON array to override your default iteration input (mutually exclusive with `parameters` and `itemSelector`). Example value: `{% {\"foo\": \"foo\", \"input\": $states.input} %}`
Default: $
jsonataMaxConcurrencyOptionalinherited from MapBaseOptionsstringJSONata expression for MaxConcurrency. A JSONata expression that evaluates to an integer, specifying the maximum concurrency dynamically. Mutually exclusive with `maxConcurrency` and `maxConcurrencyPath`. Example value: `{% $states.input.maxConcurrency %}`
Default: - full concurrency
maxConcurrencyOptionalinherited from MapBaseOptionsnumberMaxConcurrency. An upper bound on the number of iterations you want running at once.
Default: - full concurrency
AssignableStateOptionsassignOptionalinherited from AssignableStateOptions{ [key: string]: any }Workflow variables to store in this step. Using workflow variables, you can store data in a step and retrieve that data in future steps.
Default: - Not assign variables
MapBaseJsonPathOptionsitemsPathOptionalinherited from MapBaseJsonPathOptionsstringJSONPath expression to select the array to iterate over.
Default: $
maxConcurrencyPathOptionalinherited from MapBaseJsonPathOptionsstringMaxConcurrencyPath. A JsonPath that specifies the maximum concurrency dynamically from the state input.
Default: - full concurrency
resultPathOptionalinherited from MapBaseJsonPathOptionsstringJSONPath expression to indicate where to inject the state's output. May also be the special value JsonPath.DISCARD, which will cause the state's input to become its output.
Default: $
resultSelectorOptionalinherited from MapBaseJsonPathOptions{ [key: string]: any }The JSON that will replace the state's raw result and become the effective result before ResultPath is applied. You can use ResultSelector to create a payload with values that are static or selected from the state's raw result.
Default: - None
JsonPathCommonOptionsinputPathOptionalinherited from JsonPathCommonOptionsstringJSONPath expression to select part of the state to be the input to this state. May also be the special value JsonPath.DISCARD, which will cause the effective input to be the empty object {}.
Default: $
outputPathOptionalinherited from JsonPathCommonOptionsstringJSONPath expression to select part of the state to be the output to this state. May also be the special value JsonPath.DISCARD, which will cause the effective output to be the empty object {}.
Default: $
MapBaseJsonataOptionsitemsOptionalinherited from MapBaseJsonataOptionsProvideItemsThe array that the Map state will iterate over.
Default: - The state input as is.
JsonataCommonOptionsoutputsOptionalinherited from JsonataCommonOptionsanyUsed to specify and transform output from the state. When specified, the value overrides the state output default. The output field accepts any JSON value (object, array, string, number, boolean, null). Any string value, including those inside objects or arrays, will be evaluated as JSONata if surrounded by {% %} characters. Output also accepts a JSONata expression directly.
Default: - $states.result or $states.errorOutput
Everything you need to know about AWS Step Functions on one page. HD quality, print-friendly.
Download Free Infographicaws-stepfunctions