-
Notifications
You must be signed in to change notification settings - Fork 1
/
aws-kinesis-json.yaml
55 lines (48 loc) · 2.11 KB
/
aws-kinesis-json.yaml
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
id: aws-kinesis-json
namespace: company.team
tasks:
- id: put_records_simple_map
type: io.kestra.plugin.aws.kinesis.PutRecords
streamName: kestra
records:
- data: sign-in
partitionKey: user1
- data: sign-out
partitionKey: user1
- id: extract
type: io.kestra.plugin.core.http.Download
uri: https://huggingface.co/datasets/kestra/datasets/resolve/main/json/user_events.json
- id: json_to_ion
type: io.kestra.plugin.serdes.json.JsonToIon
from: "{{ outputs.extract.uri }}"
newLine: false
- id: put_records
type: io.kestra.plugin.aws.kinesis.PutRecords
streamName: kestra
records: "{{ outputs.json_to_ion.uri }}"
extend:
title: Send multiple records to AWS Kinesis Data Streams in a simple list of
maps or using a JSON API payload
description: >
This flow will send multiple records to AWS Kinesis Data Streams. The
`PutRecords` task accepts either a simple list of maps (*i.e., a list of
dictionaries*) or a URL of an internal storage file in ION format. When
extracting data from an HTTP API, you must convert the JSON payload to ION
format using the `JsonToIon` task. Then, you can pass it to the `PutRecords`
task.
The Outputs tab will display all records sent to AWS Kinesis Data Streams,
including the shard ID and sequence number. You can use these values to
retrieve the records from the stream using the `GetRecords` AWS API call.
Note that when sending the `data` payload, this must be a string value. If
you want to send a JSON object to your Kinesis Data Stream, wrap it into a
string, as shown in the [following
Gist](https://gist.githubusercontent.com/anna-geller/0b8ca0df9f4af137fc92346b360be4a7/raw/f5e7c3e1831e3d9e83d7854d133740216d82ab8d/user_events2.json).
In contrast, [this
payload](https://gist.githubusercontent.com/anna-geller/1db78ffc652f26a9904959a0040ad73c/raw/d2e630127c634c20932835e50359e933ea10493f/user_events.json)
will not work.
tags:
- AWS
- API
ee: false
demo: false
meta_description: "This flow will send multiple records to AWS Kinesis Data Streams. "